记一次http访问超时服务器端调试

问题:http访问服务器时没有返回,没有超时,一直在阻塞

处理过程:telnet端口能连上,服务端程序也不存在处理时间过长的情况。

说明tcp连接没问题。推测是客户端连接后再发起请求,服务端阻塞了。因为很多客户端会设置连接超时时间,而不设置请求超时时间。

查看jvm情况可知服务器创建了很多http-nio-9993-exec-线程,推测存在太多为关闭的连接,超出了连接数上线。

这些线程都是空闲(WAITING (parking))状态,说明客户端未正常关闭,并且服务器设置了过长的超时时间。

解决方法:修改了保活超时时间

复制代码
server:
  port: 9993
  tomcat:
#    connection-timeout: 18000000
    connection-timeout: 20000 #连接超时时间
#    keep-alive-timeout: 20000 #长连接,请求完成后保活时间,默认connection-timeout
相关推荐
Empty_7774 分钟前
K8S-网络原理
网络·容器·kubernetes
雨落秋垣1 小时前
WAF绕过技术全面解析:从原理到实践方案(简易版)
网络
黑客思维者1 小时前
为什么Linux常被提权操作?
linux·网络·安全
IT19952 小时前
C++使用“长度前缀法”解决TCP“粘包 / 拆包”问题
服务器·网络·c++·tcp/ip
一周困⁸天.2 小时前
K8S-网络组件 Calico
网络·容器·kubernetes
元亓亓亓2 小时前
考研408--计算机网络--day8--NAT&ARP&DHCP&ICMP&IPv6
网络·计算机网络·nat·arp
studytosky2 小时前
Linux 基础开发工具(3):Git 控制与 GDB 调试实用指南
linux·运维·服务器·网络·数据库·git
Ares-Wang3 小时前
网络》》生成树 STP
网络
IT_mingY3 小时前
k8S网络概述——详细理论知识
网络·容器·kubernetes
while(1){yan}3 小时前
网络协议TCP
java·网络·网络协议·tcp/ip·青少年编程·电脑常识