这篇文章主要讲解了“SpringBoot怎么监控Tomcat活动线程数来判断是否完成请求处理方式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot怎么监控Tomcat活动线程数来判断是否完成请求处理方式”吧!最近项目中有一个需求,需要判断应用的请求是否已经处理完毕,想了一下,打算通过定时任务定时监控Tomcat的活动线程数来实现。新建一个SpringBoot工程,添加定时任务定时监控,代码如下:新建一个测试免费云主机域名请求类,代码如下:启动项目:tomcatInfo: org.apache.tomcat.util.threads.ThreadPoolExecutor@49355b92[Running, pool size = 10, active threads = 0, queued tasks = 0, completed tasks = 0]
tomcatInfo: org.apache.tomcat.util.threads.ThreadPoolExecutor@49355b92[Running, pool size = 10, active threads = 0, queued tasks = 0, completed tasks = 0]访问测试接口,观察Tomcat线程池变化:tomcatInfo: org.apache.tomcat.util.threads.ThreadPoolExecutor@49355b92[Running, pool size = 10, active threads = 1, queued tasks = 0, completed tasks = 0]
complete OK
tomcatInfo: org.apache.tomcat.util.threads.ThreadPoolExecutor@49355b92[Running, pool size = 10, active threads = 0, queued tasks = 0, completed tasks = 2]可以看到,当有请求处理时,Tomcat的活动线程数不为0,处理完成以后回归到0,所以可以通过活动线程数判断当前Tomcat是否有请求还在处理,当然,应用到实际业务中,还有需要完善的地方。昨天下午4点多的时候,有同学反映说,某个服务响应时间过长,怀疑是负载均衡的问题。1,查看阿里云负载均衡表现正常,排除。2,查看单台服务日志出现OOM,可以断定是服务出问题了。1,先重启服务。2,下载 *.hprof 日志,用MAT分析结果如下图:3,结果明显指示tomcat线程池满了,并指向了其中一个controller的外部请求。4,结合代码分析是请求外部HTTP连接没有设置超时时间,导致大量请求堆积,tomcat线程池满了,造成OOM。1,HTTP请求使用连接池,设置超时响应时间2,加上监控。感谢各位的阅读,以上就是“SpringBoot怎么监控Tomcat活动线程数来判断是否完成请求处理方式”的内容了,经过本文的学习后,相信大家对SpringBoot怎么监控Tomcat活动线程数来判断是否完成请求处理方式这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是百云主机,小编将为大家推送更多相关知识点的文章,欢迎关注!
这篇文章主要介绍“Spring@value怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Spring@value怎么使用”文章能帮助大家解决问题。为了简化读取properties文件中的配置值,spring支持…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。