MQTT---HiveMQ源码详解(五)Netty-启动与Listeners加载
来源:互联网 发布:崇洋媚外的中国知乎 编辑:程序博客网 时间:2024/04/26 00:09
源博客地址:http://blog.csdn.net/pipinet123
MQTT交流群:221405150
实现功能
启动netty,按照用户配置的Listener进行端口的监听,接受客户端发来的链接
实现步骤
1、启动netty
2、通过ListenerConfigurationService获得到用户的Listener配置,将对应的配置绑定到netty上。
类图
这个uml熟悉netty的朋友应该看起来很清晰,下来我们帖几段代码,来看hivemq是如何绑定的。
public ListenableFuture<List<ListenerStartResult>> startListeners() {//为netty注册Shutdown,为了使netty主线程在关闭时,能够关闭掉worker和boss this.shutdownRegistry.register(new NettyShutdown(this.childEventLoop, this.parentEventLoop, this.hiveMQConfigurationService.internalConfiguration().getInt(Internals.EVENT_LOOP_GROUP_SHUTDOWN_TIMEOUT))); //记录Listener启动的结果的Future列表,方便在日志/控制台中打印出Listener绑定的结果。 List<ListenerStartFuture> startFutures = new ArrayList<>(); //如果用户未配置Listener,那么将默认添加一个绑定到1883端口TcpListener addDefaultListenerWhenListenersIsEmpty();//从用户配置中获得到TcpListeners绑定到netty上 startFutures.addAll(startTcpListeners(this.listenerConfigurationService.getTcpListeners()));//从用户配置中获得到TlsTcpListeners绑定到netty上 startFutures.addAll(startTlsTcpListeners(this.listenerConfigurationService.getTlsTcpListeners()));//从用户配置中获得到WebsocketListeners绑定到netty上startFutures.addAll(startWebsocketListeners(this.listenerConfigurationService.getWebsocketListeners()));//从用户配置中获得到TlsWebsocketListeners绑定到netty上startFutures.addAll(startTlsWebsocketListeners(this.listenerConfigurationService.getTlsWebsocketListeners()));//将一堆启动的Future转换成一个Future,让调用者(HiveMQServer)方便使用。 return getStartResult(startFutures); }
由上面的过程可以知道,具体代码处理流程
1、由HiveMQServer,调用NettyServer的start,启动netty。
2、然后再调用startListeners,将配置的Listeners绑定到netty上
0 0
- MQTT---HiveMQ源码详解(五)Netty-启动与Listeners加载
- MQTT---HiveMQ源码详解(八)Netty-WebSocket
- MQTT---HiveMQ源码详解(九)Netty-Codec
- MQTT---HiveMQ源码详解(十)Netty-Statistics
- MQTT---HiveMQ源码详解(十一)Netty-Throttling
- MQTT---HiveMQ源码详解(二)结构与启动
- MQTT---HiveMQ源码详解(三)配置加载
- MQTT---HiveMQ源码详解(四)插件加载
- MQTT---HiveMQ源码详解(六)Netty-Handlers总览
- MQTT---HiveMQ源码详解(七)Netty-SSL/NoSSL
- MQTT---HiveMQ源码详解(十三)Netty-MQTT消息、事件处理(源码举例解读)
- MQTT---HiveMQ源码详解(十二)Netty-MQTT消息、事件处理(流程)
- MQTT---HiveMQ源码详解(十八)Cluster-kryo与Serializer
- MQTT---HiveMQ源码详解(一)概览
- MQTT---HiveMQ源码详解(十四)Persistence-LocalPersistence
- MQTT---HiveMQ源码详解(十六)TopicTree
- MQTT---HiveMQ源码详解(外传)为什么使用Xodus
- MQTT---HiveMQ源码详解(十五)Persistence-Cluster/Single
- git分支那些事
- HBase Compaction(2)
- [第一周]Ubuntu 14.10远程登录服务器--ssh的安装和配置
- PADS之PCB导出带坐标的BOM
- mongodb导出集合
- MQTT---HiveMQ源码详解(五)Netty-启动与Listeners加载
- 近期要解决的问题
- Linux下中文输入法的安装
- 递归大总结之位运算实现加法
- 10057---JVM调优浅谈
- 笔试-数组1
- MySQL性能优化的最佳21条经验
- 笔试数组2
- 从控制台接收输入字符