Netty——ChannelOption

本文介绍了Netty中用于配置Channel的ChannelOption参数,包括SO_BACKLOG、SO_REUSEADDR、SO_KEEPALIVE、SO_SNDBUF/SO_RCVBUF、SO_LINGER以及TCP_NODELAY,这些参数与TCP/IP协议紧密相关,影响网络连接和数据传输的性能。


Netty在创建的Channel实例后,指定ChannelOption参数。ChannelOption是Socket的标准参数,而非Netty独创的。


1. ChannelOption.SO_BACKLOG

对应tcp/ip协议listen函数中的backlog参数。函数listen(int socketfd,int backlog)用来初始化服务器可连接队列。服务端处理客户端连接请求是顺序处理的,所以同一时间只能处理一个客户端连接。多个客户端来的时候,服务端将不能处理的客户端连接请求放在队列中等待处理,backlog参数指定了队列的大小。

2. ChannelOption.SO_REUSEADDR

表示允许重复使用本地地址和端口。比如某个服务器进程占用了TCP的80端口进行监听,此时再次监听该端口就会返回错误;比如某个进程非正常退出,改程序占用的端口可能要被占用一段时间才能释放此端口,允许其他进程使用。使用该参数可以解决上述问题。

3. ChannelOption.SO_KEEPALIVE

用于设置TCP连接。设置该选项后,连接会测试连接的状态。如果在两个小时内没有数据的通信时,TCP会自动发送一个保持活动探测数据报文。

4. ChannelOption.SO_SNDBUFChannelOption.SO_RCVBUF

用于操作接收缓冲区和发送缓冲区的大小。接收缓冲区用于保存网络协议栈内收到的数据,直到应用程序读取成功;发送缓冲区用于保存发送数据,直到发送成功。

5. ChannelOption.SO_LINGER

Linux内核默认的处理方式是当用户调用close()方法时,函数返回。在可能的情况下,尽量发送数据,不一定保证会有剩余的数据,造成的数据的不确定性。使用SO_LINGER可以堵塞close()的调用时间,直到数据完全发送。

6. ChannelOption.TCP_NODELAY

该参数与Nagle算法有关。Nagle算法是将小的数据包组装为更大的帧然后发送,而不是输入一次发送一次。因此在数据包不足的时候会等待其他数据到了,组装成大的数据包进行发送。虽然该方式提高了网络的负载,但是却造成了延时,而该参数的作用就是禁止使用Nagle算法,使用小数据即时传输。

TCP_NODELAY相对应的是TCP_CORK,该选项是等到发送的数据量最大的时候一次性发送数据,适用于文件传输。










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值