Bootstrap

Netty 源码分析第二讲(从 ServerBootstrap 启动类开始)

Netty 源码版本:4.1.25

为了照顾一些初学者,我们就从Netty的启动类开始 ServerBootstrap,如果基于Netty 开发高性能的服务来说,ServerBootStrap 一般是我们的第一个接触的类。

使用ServerBootstrap 启动服务的例子

ServerBootStrap 构造方法

AbstractBootstrap

ServerBootStrap 第一个重要参数 EventLoopGroup 

从 ServerBootStrap 的构造方法我们可以看出,该类主要用来进行参数配置,其中包括两个

EventLoopGroup .一个就是大家经常听到的Boss 线程,另外一个叫做work线程,借图一张,相信大家都很熟悉。

ServerBootStrap 第二个重要参数 Channel

 源码可以看到Channel是一个类的类型,在Netty 中主要有一下几个ServerSocket类型,接下来我们也主要会围绕这几种类型进行详细的源码解读。

EpollServerSocketChannel: 运行环境在Linux 下使用的一种模式
NioServerSocketChannel: 这是大家可能最熟悉的一种NIO模型,底层依赖JDK的源码实现。
KQueueServerSocketChannel: 是Mac os提供的一种NIO模式,因为基本没有人会选择使用mac作为服务器运行环境,所以对于这一类我们不做过多介绍。

  接下来几个篇章我们将主要围绕 EpollServerSocketChannel 和 NioServerSocketChannel 两种模式进行源码阅读

ServerBootStrap 第三个重要参数 option

ChannelOption.SO_BACKLOG 

具体可以参见linux 系统参数 somax,实际运行中会取两个参数中的最小值(min(SO_BACKLOG,somax))
参数表示TCP连接中同时进行三次握手,还没有被应用程序Accept 的最大个数,
该值要设置合理,太大容易因为 SYN 攻击,太小会对高并发程序来说又有影响。
这个后面我会针对linux内核参数调优进行详细的解释。
ChannelOption.ALLOCATOR 
 接受消息的Buffer处理类型,默认使用PooledByteBufAllocator

ServerBootStrap 的启动过程,主要有一些几步,每步骤的具体实现我们会在接下来的文章中一一介绍

ChannelRegistry 继承自 ChannelInitializer

 

;