记一次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
相关推荐
姓蔡小朋友4 分钟前
OSI分层模型
网络
独自破碎E44 分钟前
Java中HashMap的默认负载因子为什么设置为0.75?
java·开发语言·网络
a***59261 小时前
TCP/IP协议栈:从基础到未来趋势
网络·网络协议·tcp/ip
哎呦 你干嘛~1 小时前
服务与参数通讯介绍
网络
txinyu的博客1 小时前
TCP 队头阻塞问题
服务器·网络·tcp/ip
优选资源分享1 小时前
IPTools v5.0.8.3 专业 IP 地址修改与网卡配置工具
网络·tcp/ip·php
这儿有一堆花1 小时前
详解 TCP/IP:互联网通信的底层逻辑与现实挑战
网络·tcp/ip·php
Sleepy MargulisItG1 小时前
【Linux网络编程】网络层协议:IP
linux·网络·tcp/ip
尼古拉斯·纯情暖男·天真·阿玮1 小时前
实验六 入侵检测实验
网络·智能路由器
亲爱的非洲野猪1 小时前
如何安全关闭 IIS 的 HTTP 端口
网络·安全·http