Skip to content

:octocat: Example project for demonstrating horizontally scalability of Socket.io server with Redis Adapter

License

Notifications You must be signed in to change notification settings

hasithaishere/socket-io-redis-adapter-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Socket.io Redis Adapter Example

Example project for demonstrating horizontally scalability of Socket.io server with Redis Adapter.

Please execute following commands to check the functionality. 𝐇𝐚𝐩𝐩𝐲 𝐓𝐞𝐬𝐭𝐢𝐧𝐠 🤖

Setup Redis Locally

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.

Setup Redis

Use following command for run the Docker locally.

docker run --name socket-adapter-redis -p 6379:6379 -d redis

Start Testing

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.

socket-adapter-test-full


Contributors

About

:octocat: Example project for demonstrating horizontally scalability of Socket.io server with Redis Adapter

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published