Skip to content

Proof of concept about a simple distributed websocket service

License

Notifications You must be signed in to change notification settings

csaldiasdev/distws

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Distributed Websocket Service

Running service

# Node 1 | --httpPort 10000 --repoRpcPort 10001 --hubRpcPort 10002 --raftPort 10003 --serfPort 10004
make run-server-1

# Node 2 | --httpPort 20000 --repoRpcPort 20001 --hubRpcPort 20002 --raftPort 20003 --serfPort 20004 --member "$(LOCAL_IP):10004"
make run-server-2

# Node 3 | --httpPort 30000 --repoRpcPort 30001 --hubRpcPort 30002 --raftPort 30003 --serfPort 30004 --member "$(LOCAL_IP):10004"
make run-server-3

# Node 4 | --httpPort 40000 --repoRpcPort 40001 --hubRpcPort 40002 --raftPort 40003 --serfPort 40004 --member "$(LOCAL_IP):10004"
make run-server-4

# Node 5 | --httpPort 50000 --repoRpcPort 50001 --hubRpcPort 50002 --raftPort 50003 --serfPort 50004 --member "$(LOCAL_IP):10004"
make run-server-5

Running Load Balancer

# First install load balancer from github.com/kasvith/simplelb
make install-load-balancer

# Run load balancer with 3 nodes
make run-load-balancer-with-3-nodes

# Run load balancer with 5 nodes
make run-load-balancer-with-5-nodes

API

Message to user example

curl -H "Content-type: application/json" -d '{"message": "MESSAGE FOR USER"}' 'http://localhost:10000/api/user/{id}/message'

Websocket

Connection example

go run ./cmd/wscli/main.go --t <JWT>

JWT

Issuer: http://distributedws secret: distributedws

User One | 4f8ac4ca3ac047c6878da85a24a26ed8

# JWT
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJodHRwOi8vZGlzdHJpYnV0ZWR3cyIsInN1YiI6IjRmOGFjNGNhM2FjMDQ3YzY4NzhkYTg1YTI0YTI2ZWQ4IiwibmFtZSI6IlVzZXIgT25lIiwiaWF0IjoxNTE2MjM5MDIyfQ.pQSgLenK_tRKQeKB9XduFy8iXSlQBbZzUg1y2F9Fy-4
# WS connection example (with makefile)
make connect-user-1
# Message to user (with makefile)
make message-to-user-1 msg=MESSAGE_TO_USER

User Two | 2c4217c3def44b3fb5cfdcbd3f3d47c5

# JWT
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJodHRwOi8vZGlzdHJpYnV0ZWR3cyIsInN1YiI6IjJjNDIxN2MzZGVmNDRiM2ZiNWNmZGNiZDNmM2Q0N2M1IiwibmFtZSI6IlVzZXIgVHdvIiwiaWF0IjoxNTE2MjM5MDIyfQ.21eDhv7CawhMllxWrDgDpkiaEA23c8hyEQkcvLsocGU
# WS connection example (with makefile)
make connect-user-2
# Message to user (with makefile)
make message-to-user-2 msg=MESSAGE_TO_USER

User Three | 0b736678a31f4db392173747e4c88b76

# JWT
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJodHRwOi8vZGlzdHJpYnV0ZWR3cyIsInN1YiI6IjBiNzM2Njc4YTMxZjRkYjM5MjE3Mzc0N2U0Yzg4Yjc2IiwibmFtZSI6IlVzZXIgVGhyZWUiLCJpYXQiOjE1MTYyMzkwMjJ9.PuHqEycwze0usAQFWHpdilCRhUbE0dKQS2Tl8LwrqUU
# WS connection example (with makefile)
make connect-user-3
# Message to user (with makefile)
make message-to-user-3 msg=MESSAGE_TO_USER

User Four | ca1675075c064441a30c677aac887085

# JWT
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJodHRwOi8vZGlzdHJpYnV0ZWR3cyIsInN1YiI6ImNhMTY3NTA3NWMwNjQ0NDFhMzBjNjc3YWFjODg3MDg1IiwibmFtZSI6IlVzZXIgRm91ciIsImlhdCI6MTUxNjIzOTAyMn0.84bwBBJQ6Iqi28C1yyKxXAAtRvb_LsHnsM_qK60oIog
# WS connection example (with makefile)
make connect-user-4
# Message to user (with makefile)
make message-to-user-4 msg=MESSAGE_TO_USER

User Five | 7bcc773d086a48aab864b855530ba786

# JWT
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJodHRwOi8vZGlzdHJpYnV0ZWR3cyIsInN1YiI6IjdiY2M3NzNkMDg2YTQ4YWFiODY0Yjg1NTUzMGJhNzg2IiwibmFtZSI6IlVzZXIgRml2ZSIsImlhdCI6MTUxNjIzOTAyMn0.c992IqwXpGJYqTF6c7cAwvWQi7-XQoaY0IQ3mMciaWI
# WS connection example (with makefile)
make connect-user-5
# Message to user (with makefile)
make message-to-user-5 msg=MESSAGE_TO_USER

About

Proof of concept about a simple distributed websocket service

Topics

Resources

License

Stars

Watchers

Forks