- This service is responsible for receving data packets continuously streaming from moving cars.
- It will receive the data packets, generate the kafka payload and pump it on kafka topic to be processed by downstream services.
- It needs to be horizontally scalable as it may need to handle very large amount of data packets coming per minute if no of cars registration spikes
-
We can write reactive microservice in java which can handle very large number of requests per sec. We are using reactive stack as it does not work on thread per request model and work in non blocking mode and hence it can handle very large number of request concurrently
-
We can dockerize it and deploy them on orchestration engine either(Kubernetes or Docker swarm). We can scale in and scale out these containers as per requirement and depending on the current load in the cloud.
- LB will act as reverse proxy between Packet Gateway service and car endpoints. It will load balance the request coming from car endpoints. In this manner we can maintain high availability of the system and can tolerate outage of instances of packet gateway service
- This service is responsible for handling actual data packets.
- It will filter the valid data packets and then check for valid category by triggering rule based validation
- Finally It will produce those messages on kafka to by further produced by downstream services
- We will provide yml configuration file with the hlep of which we can simply plugin the new rule validation which will be automatically injected when the service will restart next time
- We can write this microservice in java using springboot framework.
- We need to write kafka consumer within this microservice which will estabilish conneciton to kafka cluster and process messages and will execute all the rule based validations configuration in yml file.
- We can dockerize it and deploy them on orchestration engine either(Kubernetes or Docker swarm). We can scale in and scale out these containers as per requirement and depending on the current load in the cloud.
-
Messaging Broker helps us to achieve decoupling between producer and consumer. As Both of them does not have to be available at the same time hence system is not affected if any of them goes down and also they can scale indepedently with relying on each other processing power.
-
We can increase the no of kafka partitions depending on the workload
-
We need to contiuosly publish metrics from services to reporting server in order to get the latency and throghput of the kafka consumers.
-
We can use dropwizard metrics library by adding its maven dependency in project and we can use graphite server to to accumulate above metrics
-
We can plot graffana dashhboard to get the throughput and latency of services in real time.We can also have dedeciated graph to get the consumer lag of kafka consumer of above microservices. Graffana can be configured to pull data from graphite server
-
We can set alert in graffana if specific metrics crosses specific threshold value