Cluster Auto-Healer using Zookeeper and Load Sharing between Workers with Herd Effect Avoidance
to search in text files.
## Description
in order to keep a distribued system or app running correctly with load balancing, certain characteristics must be acheived. we present simple idea of keeping a fixed number of wrokers in the cluster by watching the cluster by running master using zookeeper so when a worker fails, we launch a new worker. wrokers join the cluster register as znode in zookeeper and master keeps an eye on them.
We Have An Entry Point which is very simple Web Server that receives a search query and forward this search query to the cluster.
cluster has a master that sends the query to all workers and each wroker is responsible for a segment of the text files we have (all workers have the same text files), then we calculate the relevance of each file to the query using Entropy and set the file a score.
The Master(Coordinator) recieves answers and aggregate them by sorting the results descending by score and return answer to web server. then the client has the results.
Communication between web server and Coordinator is via GRPC
## Getting Started
### Dependencies
* zookeeper-3.9.1-dependency
* zookeeper server running in a machine (Virtual Machine or container) with identical verison of its dependency
### Installing
* change zookeeper connection info (IP + Port) as the connection to the pre-mentioned server.
* Run Nodes (Power Up VMs and Run the Project) first then Run WebServer then open browser to localhost:5566/
## simple flow
web client --> web server (grpc) --> coordinator --> (all workers)