Netty option和childOption参数
阅读数:193 评论数:0
跳转到新版页面分类
Linux
正文
一、通用参数
CONNECT_TIMEOUT_MILLIS | 连接超时毫秒数,默认值30000ms,即30s. |
MAX_MESSAGES_PER_READ | 一次Loop读取的最大消息数,对于ServerChannel或者NioByteChannel,默认值为16,其他Channel默认值为1。 |
WRITE_SPIN_COUNT | Netty参数,一个Loop写操作执行的最大次数,默认值为16。也就是说,对于大数据量的写操作至多进行16次,如果16次仍没有全部写完数据,此时会提交一个新的写任务给EventLoop,任务将在下次调度继续执行。这样,其他的写请求才能被响应不会因为单个大数据量写请求而耽误。 |
ALLOCATOR | ByteBuf的分配器。 |
RCVBUF_ALLOCATOR | 用于Channel分配接受Buffer的分配器,默认是AdaptiveRecvByteBufAllocator.DEFAULT,是一个自适应的接受缓冲区分配器。可选值FixedRecvByteBufAllocator。 |
AUTO_READ | 默认为true。该值为true,每次读操作完毕后会自动调用channel.read(),从而有数据到达便能读取,否则,需要用户手动调用channel.read()。 |
WRITE_BUFFER_HIGH_WATER_MARK | 写高水位标记,默认为64KB,如果 netty的写缓冲区的字节超过该值 ,channel的isWritable()返回false. |
WRITE_BUFFER_LOW_WATER_MARK | 写低水位标记,默认为32KB。当Netty的写缓冲区的字节超过高水位之后若下降到低水位,则Channel的isWritable()返回true。推荐做法是:每次调用channel.write(msg)方法首先调用channel.isWritable()判断是否可写。 |
MESSAGE_SIZE_ESTIMATOR | 消息大小估算器。 |
SINGLE_EVENTEXECUTOR_PER_GROUP | 单线程执行ChannelPipeline中的事件,默认值为true。这样整个pipeline由一个线程执行,这样不需要进行线程切换以及线程同步,是netty4的推荐做法。 |
二、SocketChannel参数
SO_RCVBUF | tcp数据接收缓冲区大小。该缓冲区即tcp接收滑动窗口, |
SO_SNDBUF | tcp数据发送缓冲区大小。 |
TCP_NODELAY | 立即发送数据,默认值为true。(netty默认为true,而操作系统默认为false),该值 设置Nagle算法的启用,该算法将小的报文连接成更大的报文来最小化所发送的报文数量。 |
SO_KEEPALIVE | 默认值为false,可以将此功能视为TCP的心跳机制,默认的心跳间隔是2小时。 |
SO_REUSEADDR |
地址复用,默认值 false。 有四种情况可以使用:(1)当有一个相同本地地址和端口的socket1处于TIME_WAIT状态时,而你希望启动程序的socket2要占用该地址和端口 (2)有多卡网卡或IP Alias技术的机器在同一端口启动多个进程,但每个进程绑定的本地IP地址不能相同 (3)单进程绑定相同的端口到多个socket上,但每个socket绑定的地址不同。 (4)完全相同的地址和端口的重复绑定。但这只用于UDP的多播。 |
SO_LINGER | 关闭socket的延迟时间,默认值为-1,表示禁用该功能。-1表示socket.close()方法立即返回,但OS底层会将发送缓冲区全部发送到对端。0表示socket.close()方法立即返回,放弃发送缓冲区的数据直接向对端发送RST包,对端收到复位错误。非0表示调用socket.close()方法的线程被阻塞直到延迟时间到或发送缓冲区中的数据发送完毕,若超时,则对端会收到复位错误。 |
IP_TOS | 设置IP头部的type-of-service字段,用于描述ip包的优先级和qos选项。 |
ALLOW_HALF_CLOSURE | 个连接的远端关闭时本地端是否关闭,默认值为false,表示连接自动关闭。为true时,触发ChannelInboundHandler的userEventTriggered()方法,事件为ChannelInputShutdownEvent. |
三、ServerSockerChannel参数
SO_RCVBUF | tcp数据接收缓冲区大小。该缓冲区即tcp接收滑动窗口, |
SO_REUSEADDR | 同上 |
SO_BACKLOG | 服务端接受连接的队列长度,如果队列已满,客户端连接将被拒绝。默认值 windows为200,其它为128。 |