Netty+websocket的客服聊天室

本文介绍了一个基于Netty和WebSocket的客服聊天室系统。系统通过WebSocket与Netty建立通讯,用户链接到服务器队列,由轮训机制分配客服进行点对点通讯。队列具有最大容量,客服可同时服务多个用户。当无空闲客服时,用户需排队等待。系统提供持久化操作,并提供详细目录结构和API参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Netty所需jar包
commons-beanutils-1.8.0.jar
commons-collections-3.2.jar
commons-logging.jar
commons-lang-2.4.jar
ezmorph-1.0.6.jar
json-lib-2.4-jdk15.jar 这里使用org.
log4j-1.2.17.jar
netty-all-4.1.6.Final.jar

系统概要(懒得做图就看文字吧)
1. 用户通过websocket与netty创建通讯
2. 用户链接到服务器队列中
3. 队列通过轮训机制判定netty是否有可以服务的客服
4. 如果有则将队列中的用户channel转给客服进行点对点通讯
5. 队列有自己的最大容载量
6. 每个客服可以同时服务N个用户
7. 没有空闲客服的时候用户们只能在队列中慢慢排队
8. 队列状态及实时位置由队列向队列内用户推送
9. 当有空闲位置的时候,轮训机制会将队列中首位用户放到netty中进行与客服的通讯挂钩
10. 其实对于服务器队列可以抽出来做到一个单独的项目中,用户先访问队列项目,队列项目再将用户channel发送给处理消息的netty项目

这个demo仅供学习使用,对于粘包可以自行处理(缓冲区及LineBasedFrameDecoder的使用),对于新的需求迭代参考MsgExecute.java ,对于持久化操作参考DbService.java

Netty4.1 API
http://netty.io/4.1/api/index.html

目录结构

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值