Netty 源码版本:4.1.25
为了照顾一些初学者,我们就从Netty的启动类开始 ServerBootstrap,如果基于Netty 开发高性能的服务来说,ServerBootStrap 一般是我们的第一个接触的类。
使用ServerBootstrap 启动服务的例子
data:image/s3,"s3://crabby-images/b73ea/b73ea3d8753810a032c98ce7dcc50641e3b6a924" alt=""
ServerBootStrap 构造方法
data:image/s3,"s3://crabby-images/c525a/c525ad9a8294423f10ccdf0cd0c775651330436d" alt=""
AbstractBootstrap
data:image/s3,"s3://crabby-images/4796f/4796fcfcfd3c0230c3f44a27ec52f00685b75c4b" alt=""
ServerBootStrap 第一个重要参数?EventLoopGroup?
从 ServerBootStrap 的构造方法我们可以看出,该类主要用来进行参数配置,其中包括两个
EventLoopGroup .一个就是大家经常听到的Boss 线程,另外一个叫做work线程,借图一张,相信大家都很熟悉。
data:image/s3,"s3://crabby-images/c3053/c30535fd2cfd8913a3b5d6fc007596efc4aa6c49" alt=""
ServerBootStrap 第二个重要参数?Channel
?源码可以看到Channel是一个类的类型,在Netty 中主要有一下几个ServerSocket类型,接下来我们也主要会围绕这几种类型进行详细的源码解读。
data:image/s3,"s3://crabby-images/2468c/2468cd897095d55a1078b50935c4696e8e787a8c" alt=""
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 的启动过程,主要有一些几步,每步骤的具体实现我们会在接下来的文章中一一介绍
data:image/s3,"s3://crabby-images/1bfa3/1bfa3e760ba4755b99d23e597e7478accb3483da" alt=""
ChannelRegistry 继承自 ChannelInitializer
data:image/s3,"s3://crabby-images/23901/239017b02481ba7e531fbd3b0d9cc0999afd6fe4" alt=""
?
|