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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
2019-01-23 托马斯微积分13版原版pdf