作者:sherklock | 来源:互联网 | 2023-05-17 19:50
源博客地址:http:blog.csdn.netpipinet123MQTT交流群:221405150实现功能启动netty,按照用户配置的Listener进行
源博客地址:http://blog.csdn.net/pipinet123
MQTT交流群:221405150
实现功能
启动netty,按照用户配置的Listener进行端口的监听,接受客户端发来的链接
实现步骤
1、启动netty
2、通过ListenerConfigurationService获得到用户的Listener配置,将对应的配置绑定到netty上。
类图
这个uml熟悉netty的朋友应该看起来很清晰,下来我们帖几段代码,来看hivemq是如何绑定的。
public ListenableFuture> startListeners() {
this.shutdownRegistry.register(new NettyShutdown(this.childEventLoop, this.parentEventLoop, this.hiveMQConfigurationService.internalConfiguration().getInt(Internals.EVENT_LOOP_GROUP_SHUTDOWN_TIMEOUT)));
List startFutures = new ArrayList<>();
addDefaultListenerWhenListenersIsEmpty();
startFutures.addAll(startTcpListeners(this.listenerConfigurationService.getTcpListeners()));
startFutures.addAll(startTlsTcpListeners(this.listenerConfigurationService.getTlsTcpListeners()));
startFutures.addAll(startWebsocketListeners(this.listenerConfigurationService.getWebsocketListeners()));
startFutures.addAll(startTlsWebsocketListeners(this.listenerConfigurationService.getTlsWebsocketListeners()));
return getStartResult(startFutures);
}
由上面的过程可以知道,具体代码处理流程
1、由HiveMQServer,调用NettyServer的start,启动netty。
2、然后再调用startListeners,将配置的Listeners绑定到netty上