基于手写muduo网络库实现的集群聊天服务器和客户端代码,网络框架是经典的one thread one loop框架,并通过nginx实现tcp负载均衡、还通过redis消息订阅实现跨服务器聊天。
cd build rm -rf * cmake .. make
- 需要配置nginx负载均衡,启动nginx
- 启动reids服务
- 启动mysql,配置数据库和表
- 启动服务器:./ChatServer 127.0.0.1 6000/6002(负载均衡中配置6000和6002两个端口)
- 启动客户端:./ChatClient 127.0.0.1 80000(连接的是nginx服务器的端口,复杂算法会根据权重进行分配到对应的服务器中)
- muduo核心网络的编写, 采用one thread one loop模型**,主线程做侦听线程,用于侦听客户端连接,并将客户端连接通过轮询的方式分配给工作线程,每个线程中有一个EventLoop的事件循环,中间有epoll_wait监听发生事件的句柄,并执行相应的回调。
- 基于手写的网络库,实现了一个聊天服务器,并基于命令行,实现了一个简单的客户端,可以完成用户注册、登录、添加好友、创建群、添加群、单聊、群聊、注销功能。
- 通过nginx负载均衡,实现了实现了集群服务器,不同用户可以通过负载算法登录在不同的服务器中。
- 通过redis的订阅发布操作,实现了不同用户跨服务器聊天的问题
- 使用第三方的json库实现传输消息的序列化和反序列化
- QT实现聊天室界面
- 将序列化和反序列化的方式改为websocket协议传输
- 添加文件传输功能(不同用户之间发生文件)