一个基于Netty的聊天工具(开发中),使用Zookeeper+Redis实现服务端分布式部署。
客户端
与服务端
的连接,通过路由端
选择可用服务端
节点服务端
启动后,向Zookeeper
注册自己客户端
发送消息通过路由端
,选择对应的服务端
进行推送消息路由端
无状态,集群部署只需要一个Nginx
代理即可
- 客户端服务端连接
- 客户端处理用户输入消息
- 消息序列化(Protobuf)
- 服务端注册
- 路由端获取可用服务端节点
- 消息群发功能
- 客户端下线(强制下线/主动下线)
- 服务端断线,客户端重连
- 心跳
- 消息重发
- 聊天记录
- 离线消息
1.启动redis与Zookeeper,修改redis、Zookeeper配置
2.编译、打包
mvn -Dmaven.test.skip=true clean package
3.启动路由
java -jar im-route\target\im-route-0.0.1-SNAPSHOT.jar
4.启动服务端
java -jar im-server\target\im-server-0.0.1-SNAPSHOT.jar --server.port=8084 --im.server.port=8090
java -jar im-server\target\im-server-0.0.1-SNAPSHOT.jar --server.port=8085 --im.server.port=8091
5.启动客户端
java -jar im-client\target\im-client-0.0.1-SNAPSHOT.jar --server.port=8071 --im.user.id=1001 --im.user.userName=Five
java -jar im-client\target\im-client-0.0.1-SNAPSHOT.jar --server.port=8072 --im.user.id=1002 --im.user.userName=Luffy