Netty之ChannelOption
来源:互联网 发布:ubuntu软件中心 编辑:程序博客网 时间:2024/06/04 18:01
一、概述
最近在写一个分布式服务框架,打算用netty框架做底层网络通信,关于netty的学习可以参考如下资料:
http://blog.csdn.net/column/details/enjoynetty.html
李林锋的《Netty权威指南》
二、详情
在用netty作为底层网络通信的时候关于ChannelOption的参数让我一直模糊不清楚,于是去看一下linux网络编程,发现ChannelOption的各种属性在套接字选项中都有对应
下面简单的总结一下ChannelOption的含义已及使用的场景
1、ChannelOption.SO_BACKLOG
ChannelOption.SO_BACKLOG对应的是tcp/ip协议listen函数中的backlog参数,函数listen(int socketfd,int backlog)用来初始化服务端可连接队列,
服务端处理客户端连接请求是顺序处理的,所以同一时间只能处理一个客户端连接,多个客户端来的时候,服务端将不能处理的客户端连接请求放在队列中等待处理,backlog参数指定了队列的大小
2、ChannelOption.SO_REUSEADDR
ChanneOption.SO_REUSEADDR对应于套接字选项中的SO_REUSEADDR,这个参数表示允许重复使用本地地址和端口,
比如,某个服务器进程占用了TCP的80端口进行监听,此时再次监听该端口就会返回错误,使用该参数就可以解决问题,该参数允许共用该端口,这个在服务器程序中比较常使用,
比如某个进程非正常退出,该程序占用的端口可能要被占用一段时间才能允许其他进程使用,而且程序死掉以后,内核一需要一定的时间才能够释放此端口,不设置SO_REUSEADDR
就无法正常使用该端口。
3、ChannelOption.SO_KEEPALIVE
Channeloption.SO_KEEPALIVE参数对应于套接字选项中的SO_KEEPALIVE,该参数用于设置TCP连接,当设置该选项以后,连接会测试链接的状态,这个选项用于可能长时间没有数据交流的
连接。当设置该选项以后,如果在两小时内没有数据的通信时,TCP会自动发送一个活动探测数据报文。
4、ChannelOption.SO_SNDBUF和ChannelOption.SO_RCVBUF
ChannelOption.SO_SNDBUF参数对应于套接字选项中的SO_SNDBUF,ChannelOption.SO_RCVBUF参数对应于套接字选项中的SO_RCVBUF这两个参数用于操作接收缓冲区和发送缓冲区
的大小,接收缓冲区用于保存网络协议站内收到的数据,直到应用程序读取成功,发送缓冲区用于保存发送数据,直到发送成功。
5、ChannelOption.SO_LINGER
ChannelOption.SO_LINGER参数对应于套接字选项中的SO_LINGER,Linux内核默认的处理方式是当用户调用close()方法的时候,函数返回,在可能的情况下,尽量发送数据,不一定保证
会发生剩余的数据,造成了数据的不确定性,使用SO_LINGER可以阻塞close()的调用时间,直到数据完全发送
6、ChannelOption.TCP_NODELAY
ChannelOption.TCP_NODELAY参数对应于套接字选项中的TCP_NODELAY,该参数的使用与Nagle算法有关
Nagle算法是将小的数据包组装为更大的帧然后进行发送,而不是输入一次发送一次,因此在数据包不足的时候会等待其他数据的到了,组装成大的数据包进行发送,虽然该方式有效提高网络的有效
负载,但是却造成了延时,而该参数的作用就是禁止使用Nagle算法,使用于小数据即时传输,于TCP_NODELAY相对应的是TCP_CORK,该选项是需要等到发送的数据量最大的时候,一次性发送
数据,适用于文件传输。
三、总结
最近使用netty感觉netty真的很强大,也很好用,推荐大家学习一下。
- Netty之ChannelOption
- Netty之ChannelOption
- Netty之ChannelOption
- netty之ChannelOption
- Netty之ChannelOption
- Netty之ChannelOption
- netty实战之ChannelOption配置
- Netty 之 ChannelOption的TCP_NODELAY属性设置
- Netty ChannelOption 参数含义
- Netty中的ChannelOption
- Netty——ChannelOption
- Java网络编程之Netty服务端ChannelOption.SO_BACKLOG配置-yellowcong
- 一起学Netty(十六)之 ChannelOption的TCP_NODELAY属性设置
- Netty中ChannelOption中各个字段表示内容
- Java netty的option(ChannelOption.SO_BACKLOG,1024 )的意思
- Java netty的option(ChannelOption.SO_BACKLOG, backLog)什么意思
- Netty 常量池实现以及ChannelOption与Attribute作用分析
- netty源码分析(十一)Netty常量池实现及ChannelOption与Attribute作用分析
- 2145: 2017湖南多校第十三场-20170723
- java丶JsonObject 的使用
- cordova media-capture插件
- eclipse运行maven项目报错java.lang.ClassNotFoundException: xxxxxx
- C
- Netty之ChannelOption
- [leetcode]68. Text Justification@Java解题报告
- toJSON时间格式化
- Matlab图形窗口大小的控制 ,plot窗口大小,figure大小,axis设置
- python获取群成员信息
- 用html5自带表单验证 并且用ajax提交的解决方法(附代码)
- BZOJ 1702 [Usaco2007 Mar]Gold Balanced Lineup 平衡的队列 stl--map
- 笔记本中ubuntu系统待机睡眠后无法登陆,只剩光标的解决办法
- 比特币(Bitcoin)伪挖矿教程