属性 | 描述 |
---|---|
ALLOCATOR | 默认值,使用对象池,重用缓冲区 |
ALLOW_HALF_CLOSURE | 关闭连接时,允许半关,默认不允许;TCP 是双向通道;半关之后,Server 还是可以向 Client 发数据,只是不能从 Client 再读数据,Client 也不能向 Server 发数据了; |
AUTO_READ | 一个连接的远端关闭时本地端是否关闭,默认值为False。值为False时,连接自动关闭;为True时,触发ChannelInboundHandler的userEventTriggered()方法,事件为ChannelInputShutdownEvent。 |
CONNECT_TIMEOUT_MILLIS | 连接超时毫秒数,默认值30000毫秒即30秒。 |
IP_MULTICAST_ADDR | 对应IP参数IP_MULTICAST_IF,设置对应地址的网卡为多播模式。 |
IP_MULTICAST_IF | 对应IP参数IP_MULTICAST_IF,设置对应地址的网卡为多播模式。 |
IP_MULTICAST_LOOP_DISABLED | 对应IP参数IP_MULTICAST_LOOP,设置本地回环接口的多播功能。由于IP_MULTICAST_LOOP返回True表示关闭,所以Netty加上后缀_DISABLED防止歧义。 |
IP_MULTICAST_TTL | IP参数,多播数据报的time-to-live即存活跳数。 |
IP_TOS | IP参数,设置IP头部的Type-of-Service字段,用于描述IP包的优先级和QoS选项。 |
MESSAGE_SIZE_ESTIMATOR | 消息大小估算器,默认为DefaultMessageSizeEstimator.DEFAULT。估算ByteBuf、ByteBufHolder和FileRegion的大小,其中ByteBuf和ByteBufHolder为实际大小,FileRegion估算值为0。该值估算的字节数在计算水位时使用,FileRegion为0可知FileRegion不影响高低水位。 |
RCVBUF_ALLOCATOR | 用于Channel分配接受Buffer的分配器,默认值为AdaptiveRecvByteBufAllocator.DEFAULT,是一个自适应的接受缓冲区分配器,能根据接受到的数据自动调节大小。可选值为FixedRecvByteBufAllocator,固定大小的接受缓冲区分配器。 |
SINGLE_EVENTEXECUTOR_PER_GROUP | 单线程执行ChannelPipeline中的事件,默认值为True。该值控制执行ChannelPipeline中执行ChannelHandler的线程。如果为True,整个pipeline由一个线程执行,这样不需要进行线程切换以及线程同步,是Netty4的推荐做法;如果为False,ChannelHandler中的处理过程会由Group中的不同线程执行。 |
SO_BACKLOG | 对应的是tcp/ip协议listen函数中的backlog参数,backlog参数指定了队列的大小 |
SO_BROADCAST | Socket参数,设置广播模式。 |
SO_KEEPALIVE | 对应于套接字选项中的SO_KEEPALIVE,该参数用于设置TCP连接,当设置该选项以后,连接会测试链接的状态,这个选项用于可能长时间没有数据交流的连接。当设置该选项以后,如果在两小时内没有数据的通信时,TCP会自动发送一个活动探测数据报文。 |
SO_LINGER | 对应于套接字选项中的SO_LINGER,Linux内核默认的处理方式是当用户调用close()方法的时候,函数返回,在可能的情况下,尽量发送数据,不一定保证会发送剩余的数据,造成了数据的不确定性,使用SO_LINGER可以阻塞close()的调用时间,直到数据完全发送 |
SO_RCVBUF | 对应于套接字选项中的SO_RCVBUF,用于操作接收缓冲区的大小,接收缓冲区用于保存网络协议站内收到的数据,直到应用程序读取成功 |
SO_SNDBUF | 对应于套接字选项中的SO_SNDBUF,用于操作发送缓冲区的大小,发送缓冲区用于保存发送数据,直到发送成功。 |
SO_REUSEADDR | 对应于套接字选项中的SO_REUSEADDR,这个参数表示允许重复使用本地地址和端口,比如,某个服务器进程占用了TCP的80端口进行监听,此时再次监听该端口就会返回错误,使用该参数就可以解决问题,该参数允许共用该端口,这个在服务器程序中比较常使用,比如某个进程非正常退出,该程序占用的端口可能要被占用一段时间才能允许其他进程使用,而且程序死掉以后,内核一需要一定的时间才能够释放此端口,不设置SO_REUSEADDR就无法正常使用该端口。 |
SO_TIMEOUT | 这个参数设定的是HTTP连接成功后,等待读取数据或者写数据的最大超时时间,单位为毫秒 。如果设置为0,则表示永远不会超时 |
TCP_NODELAY | 对应于套接字选项中的TCP_NODELAY,该参数的使用与Nagle算法有关。Nagle算法是将小的数据包组装为更大的帧然后进行发送,而不是输入一次发送一次,因此在数据包不足的时候会等待其他数据的到了,组装成大的数据包进行发送,虽然该方式有效提高网络的有效负载,但是却造成了延时,而该参数的作用就是禁止使用Nagle算法,使用于小数据即时传输,于TCP_NODELAY相对应的是TCP_CORK,该选项是需要等到发送的数据量最大的时候,一次性发送数据,适用于文件传输。 |
WRITE_SPIN_COUNT | 一个Loop写操作执行的最大次数,默认值为16。也就是说,对于大数据量的写操作至多进行16次,如果16次仍没有全部写完数据,此时会提交一个新的写任务给EventLoop,任务将在下次调度继续执行。这样,其他的写请求才能被响应不会因为单个大数据量写请求而耽误。 |
参考文档:
https://blog.csdn.net/horse_xiao/article/details/94652102
https://blog.csdn.net/qq_28198181/article/details/82152338