Example project for demonstrating horizontally scalability of Socket.io server with Redis Adapter.
Please execute following commands to check the functionality. 𝐇𝐚𝐩𝐩𝐲 𝐓𝐞𝐬𝐭𝐢𝐧𝐠 🤖
If you haven't setup Redis locally, first you need to install Redis locally or need to run Redis as a container in your system. Docker based setup is recommended.
Use following command for run the Docker locally.
docker run --name socket-adapter-redis -p 6379:6379 -d redis
Please execute following command to run the server. Server will start on port 3000
.
node server.js 3000
For testing purpose, you need to run secondary server on different port(ex - Port 3001).
node server.js 3001
When you start the servers it will connect with the Redis and make the bridge between two socket servers.
For testing this functionality, please spin up following two clients using these commands.
Client 1
node client-1.js
Client 2
node client-2.js
After the client starts publishing and receiving messages, you can observe that both clients receive all the messages from both servers. However, if these servers are disconnected and run individually, this scenario becomes infeasible. Therefore, it implies that both servers are bridged using a Redis adapter.
For more information please check following screen capture.