一次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
原文地址:https://blog.csdn.net/yaoct/article/details/137688390
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!