This project is a Java-based real-time chat application that can support the concurrent usage of multiple users. We use bash scripts to start the servers and client, monitor the liveliness and handle failures of the servers.
- Start the servers:
- There are 4 parts in the server cluster: database, route, login service, room service. Each part contains multiple servers
- First, use './run_rmiregistry.sh' to start the RMI registry for internal service. You might need to wait for a few seconds before starting the servers.
- Second, run './build.sh' to build the project.
- Then, use './start_cluster.sh' to start all servers in the 4 parts. The bash program then is responsible for keep all server processes alive, so do not close the terminal running the bash script.
- Ports 8080, 8081, 8082, 8083, 8090, 8091 may be used for HTTP listening, please make sure these ports are available.
- Start the client:
- After starting the server, use './start_client.sh' to start a client program
- To open multiple user interface, just run './start_client.sh' again
- Stop the servers:
- Press 'Ctrl+C' in the terminal running the start_cluster.sh script, which will stop the bash program
- Use './stop_cluster.sh' to stop all servers running background
- Use './clear.sh' to clean the files created in /log and /target
Key design goals: scalability, concurrency, and transparency. Main distributed systems algorithms applied: Fault-tolerance, replicated database management, Distributed Consensus using PAXOS, and group communication.