记一次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
相关推荐
北 染 星 辰19 分钟前
WLAN 技术指南:从入门到原理
网络协议
工程师00721 分钟前
C#AES加密
网络·安全·web安全·c#
厦门辰迈智慧科技有限公司1 小时前
水库大坝安全监测之渗流监测
网络·物联网·安全
sztomarch2 小时前
Router-Routing
linux·运维·服务器·前端·网络
茉莉玫瑰花茶2 小时前
传输层协议TCP(下)
服务器·网络·tcp/ip
achene_ql2 小时前
手写muduo网络库(七):深入剖析 Acceptor 类
linux·服务器·开发语言·网络·c++
爱分享的程序员2 小时前
前端面试专栏-基础篇:5. HTTP/2 协议深度解析
网络·网络协议·http
rit84324992 小时前
Odoo 17 在线聊天报错 “Couldn‘t bind the websocket...“ 的解决方案
网络·websocket·网络协议
bing_1582 小时前
Spring Boot 项目中Http 请求如何对响应体进行压缩
spring boot·后端·http
ArabySide2 小时前
【JavaScript】 HTTP Cookie 核心知识梳理与常用的封装实现
javascript·计算机网络·http·web