Skip to content

docker-compose.yml with Kafka, ZooKeeper, ElasticSearch and a web api server.

Notifications You must be signed in to change notification settings

SaiPrasanna9/kafka-elasticsearch

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Flask, Kafka & ElasticSearch Playground

Description

Build a webapi that will POST requests to kafka, consume the requests from kafka and will send the consumned requests to elasticsearch. The api will also support get requests from elasicsearch that will return a list of objects that matched a message that was previously sent to elastic.

Note

if the message string done not exist in elastic, return empty list.

How to run

  1. git clone this repo
  2. cd to this repo
  3. Run: docker-compose up --build
  4. Wait for the container to finish loading
  5. Run the http requests

Using

  1. Flask - python HTTP server:

    • GET localhost:5000/health - Health check for the web-server.
    • POST localhost:5000/message - Send message with string as raw data to Kafka, then consume kafka and send the data to ElasticSearch.
    • GET localhost:5000/message/<msg> - Get all msg from ElasticSearch.

API tests via CURL

  1. curl -X POST http://localhost:5000/message -H 'content-type: text/plain' -d hello
  2. curl -X GET http://localhost:5000/message/hello

POST 5 messages with string "hello" and invoke GET from elastic

[
    {
        "message": "hello",
        "timestamp": 1553376078.751528
    },
    {
        "message": "hello",
        "timestamp": 1553370386.6626382
    },
    {
        "message": "hello",
        "timestamp": 1553382277.687757
    },
    {
        "message": "hello",
        "timestamp": 1553382381.1357608
    },
    {
        "message": "hello",
        "timestamp": 1553382391.81499
    }
]

GET string "missing" from elastic without invoking the string via POST

[]

Future Improvements

Use confluentinc/kafka-connect-elasticsearch to send data directly from kafka to ElasticSearch.

About

docker-compose.yml with Kafka, ZooKeeper, ElasticSearch and a web api server.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 87.5%
  • Dockerfile 12.5%