美文网首页MQTT
MQTT---HiveMQ源码详解(五)Netty-启动与Lis

MQTT---HiveMQ源码详解(五)Netty-启动与Lis

作者: 西安PP | 来源:发表于2017-10-22 01:37 被阅读43次

    实现功能

    启动netty,按照用户配置的Listener进行端口的监听,接受客户端发来的链接

    实现步骤

    1、启动netty
    2、通过ListenerConfigurationService获得到用户的Listener配置,将对应的配置绑定到netty上。

    类图

    listener

    这个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上


    MQTT交流群:221405150

    RocketMQ交流群:10648794

    NewSQL交流群:153575008


    相关文章

      网友评论

        本文标题:MQTT---HiveMQ源码详解(五)Netty-启动与Lis

        本文链接:https://www.haomeiwen.com/subject/jftguxtx.html