zoukankan      html  css  js  c++  java
  • Netty服务端创建流程及组件职责

    public class NettyServer {
        public static void main(String[] args) throws InterruptedException {
            NioEventLoopGroup boosGruop = new NioEventLoopGroup();
            NioEventLoopGroup workerGroup = new NioEventLoopGroup();
    
            ServerBootstrap serverBootstrap = new ServerBootstrap();
    
            serverBootstrap.group(boosGruop,workerGroup)
                    .channel(NioServerSocketChannel.class)
                    .childHandler(new ChannelInitializer<NioSocketChannel>() {
                        @Override
                        protected void initChannel(NioSocketChannel nioSocketChannel) throws Exception {
                                nioSocketChannel.pipeline().addLast(new FirstServerHandler());
                        }
                    });
    
            ChannelFuture f = serverBootstrap.bind(8000).sync();
            f.channel().closeFuture().sync();
    
        }
    }

    ServerBootStrap 

      服务端的辅助启动类,使用Builder模式隐藏了多个构造器的参数。

    EventLoopGroup

      Reactor线程池。EventLoopGroup是EventLoop数组,EventLoop负责轮询所有注册到Selector上的channel。

    绑定Channel

      用于指定服务端使用何种channel,可选的有NIO(NioServerSocketChannel)和BIO。netty屏蔽了这两种IO在使用上的区别,方便用户在NIO和BIO之间快速切换。由于在channel中传入的是一个类,所以这里是通过反射创建对象。

    ChannelPipeline与ChannelHandler

      用来处理网络时间的责任链,负责管理和执行ChannelHandler,依据不同的网络时间调用ChannelHandler的不同方法去响应网络事件。除了用户自定义的ChannelHandler还有Netty提供的。

    绑定端口

      这一步完成把Channel注册到Selector上

    Selector轮询

      由EventLoop负责调度和执行Selector操作

    调用执行ChannelHandler

      当注册的时间发生后,会调用ChannelPipeline并继而调用响应的ChannelHandler

  • 相关阅读:
    【程序员面试宝典】第五章 程序设计基本概念
    win7打开或关闭windows功能 提示“出现错误,并非所有的功能被更改”,管理员权限惹的祸
    堆排序
    目态与管态的概念
    循环不变式的概念
    getchar()函数的返回值赋给char型,用if(ch=getchar() != EOF)测试,输入ctrl+z同样可以结束循环的分析
    java算法 -- 冒泡排序
    Java算法 -- 二分查找
    Sql知识点总结
    java实现 链表反转
  • 原文地址:https://www.cnblogs.com/AshOfTime/p/10874401.html
Copyright © 2011-2022 走看看