tomcat启动很慢很慢,长达122873ms

本文详细描述了作者在启动Tomcat时遇到的长时间延迟问题,通过strace工具定位到问题根源在于/dev/random导致的阻塞。了解到Tomcat在启动时使用随机数生成器来提高安全性,而/Linux下的/dev/random在熵池不足时会阻塞。解决方案包括:1) 修改Tomcat或JRE配置使用/dev/urandom;2) 增大/dev/random熵池,如使用rngd服务。作者推荐使用第三种方法,即通过rngd服务提高熵池生成速度,以从根本上解决问题。
摘要由CSDN通过智能技术生成

tomcat在启动后,查看日志。发现tomcat的启动非常慢 如下图
这里写图片描述

我查看了一下进程,Tomcat所在的JVM进程已经被启动了所以可以排除是JVM退出引起的问题。那么问题真的就是JVM因为某种原因被阻塞了。
● 分析
问题比较棘手,我排除了CPU、内存不足引起的问题;排除了硬盘空间不足引起的问题;我甚至去观察了网络I/O、硬盘I/O情况,都非常正常。程序被阻塞一般来说一定是要等待某个资源,而现在的情况是所有资源都充足,所以我几乎想不到是什么问题引起的。我开始怀疑是KVM Hypervisor虚拟化的问题(用的是虚拟机)我改变了策略在VMWare开了两台虚拟机上直接下载Tomcat启动。其中一台很快启动,另一台居然也被阻塞,问题被重现了。况且Tomcat那么多人用,真有这么明显的Bug早就炸开锅了。无可奈何的情况下我决定试一下 strace,这是一个跟踪系统调用(System Call)的工具,无论是Java还是Pyhton很多资源申请都会变成都会变成System Call。(比如打开文件、新建线程、读写数据、等待I/O)通过这个工具我至少可以知道Tomcat是停止在哪个System Call上的,这样可以方便我推断出问题的原因。
strace -f -o strace.out ./catalina.sh run
strace有很多参数,我用了二个

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值