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
目录结构