记一次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
相关推荐
谢怜826 分钟前
计算机网络第三章数据链路层
网络·计算机网络
热心市民R先生17 分钟前
对象字典(OD)、服务数据对象(SDO)、过程数据对象(PDO)(二)
服务器·网络
希赛网25 分钟前
网工面试:常问技术问题汇总(4)
网络·计算机网络·网络工程师·面试问题·路由交换·网工面试·网工面试提问
(Charon)38 分钟前
【网络编程】基于 DPDK 的 UDP/TCP 抓包与最简协议栈实现
网络·tcp/ip·udp
zbtlink42 分钟前
路由器桥接:原理、差异与操作指南
网络·智能路由器
mjr1 小时前
基于Netty的WebSocket实时消息推送系统
网络·websocket·网络协议
jiayong231 小时前
Kubernetes 网络与服务发现面试题详解
网络·kubernetes·服务发现
少云清1 小时前
【性能测试】3_Locust _locust实现混合业务实现
网络·性能测试·locust
venus601 小时前
网络运维之ping与telnet的区别
运维·服务器·网络
WinyQ02 小时前
【DeepStream】整合出现的问题
linux·运维·网络