数学建模社区-数学中国
标题:
关于linux下socket的连接队列backlog的分析
[打印本页]
作者:
爱是你我
时间:
2015-4-14 11:39
标题:
关于linux下socket的连接队列backlog的分析
linux在对socket的连接队列的定义处理上个人觉得是有点坑爹的,闲话少说,直接开讲。
, Q. ^) p6 p( c0 H d) B3 A! u9 I8 S
6 y3 b7 L9 V9 y' @
建立socket连接的过程:
# a/ i' `% l: `# {2 D; d6 ~
1.client发syn请求给server
/ Q, E |: w" w& S- _# T4 i
2.server收到后把请求存放在SYN queue里,这个半连接队列的最大值是系统参数 tcp_max_syn_backlog定义的
$ H$ _5 @5 x" Y5 f5 w. ?. b
3.存放在半连接队列后发送syn+ack给client,client收到后再发syn+ack给server完成三次握手,然后server把连接存放在accept queue ,这个队列长度就是程序里调用socket的时候定义的backlog定义大小。
- ^& N' h% P$ k! l
4.应用程序通过调用accept()到accept queue里获取连接。
) \3 ^# I* Q l+ Q4 |/ C
坑爹的特性来了!注意!
& I4 l% v8 n( I1 T
当accept queue满了会怎么样?
$ I* \8 [9 Z A2 M! @/ k0 c
!!注意!如果accept队列满了,linux会出现一个异常处理,去判断tcp_abort_on_overflow系统参数是否为1,如果为1 ,则会发出拒绝客户端的终止讯息并断开连接。但是如果这个参数是0,那就坑爹了!,对于溢出队列的连接,linux不会去管它,会继续正常建立连接,但是在accept queue里没有,那就意味着你的程序用accept()函数无法取的连接!这是多么的坑爹啊!!!根本查不出原因好么!!!各种被误导好么!!!尼玛linux啊!!
5 ]8 U! b% m9 |2 m$ T; J" s
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5