nginx defer_accept 分析

 

netstat发现很多TCPDeferAcceptDrop的统计

 

nignx的listen配置里设置了defered选项。

查看代码发现是设置了listen socket的TCP_DEFER_ACCEPT的选项。

/nginx/src/core/ngx_connection.c::ngx_configure_listening_sockets()

 

man 7 tcp 查看Linux的文档,可以看到,建立之后1秒内,没有发数据的连接停止重发报文。

 

查看内核源码

linux/net/ipv4/tcp_minisocks.c::tcp_check_req()

握手的第三个ack如果没有带data,就不会建立新的socket,也就是说nginx的accept不会返回新socket。

然后这个到达的ack会导致上文的计数加1.

 defer的超时时间设置在变量rskq_defer_accept上。把时间转换为重传次数。

net/ipv4/tcp.c::do_tcp_setsockopt()

 socket会在defer超时到期以后并且一直没有收到ack时,会记录一次计数TCPTIMEOUTS,并重传synack,并计数LINUX_MIB_TCPSYNRETRANS和TCP_MIB_RETRANSSEGS

 

 

posted on   toong  阅读(5)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
历史上的今天:
2019-01-23 托马斯微积分13版原版pdf

统计

点击右上角即可分享
微信分享提示