记一次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
相关推荐
不染尘.3 分钟前
超网和路由概述
网络·计算机网络
2501_9388101113 分钟前
共享IP的弊端
服务器·网络·tcp/ip
ICT技术最前线14 分钟前
怎样配置路由器网络,让办公效率翻倍?
网络·智能路由器
lx1885486989637 分钟前
HTTPS总结
服务器·网络协议·https
2501_9151063244 分钟前
App HTTPS 抓包实战解析,从代理调试到真实网络流量观察的完整抓包思路
网络协议·http·ios·小程序·https·uni-app·iphone
邵小的运维之路1 小时前
本实验基于静态路由与 NQA 联动
网络
yuan199971 小时前
基于C#实现斑马打印机自动化包装打印
网络·c#·自动化
不懂机器人1 小时前
CAN总线协议
网络
咕噜签名-铁蛋1 小时前
火山引擎:字节跳动技术火山喷发,赋能千行百业智能升级
服务器·网络