tomcat启动异常缓慢

本文探讨了Tomcat启动缓慢的原因,主要集中在SecureRandom类的实例化上,尤其是在Linux环境下。SecureRandom使用/dev/random作为熵源,当熵池不足时,会导致启动延迟。解决方案包括增大熵池(通过rng-tools服务)和修改Tomcat或JVM配置,使用非阻塞的Entropy Source(/dev/./urandom)。这两种方法都可以显著提高Tomcat的启动速度。
摘要由CSDN通过智能技术生成

引言

最近弄了个服务器再部署了个javaweb项目,但是再启动时候 发现Tomcat启动非常非常的慢,导致再部署完成以后 觉得项目像 没有起来一样, 这就很郁闷了,因为每次不熟需要等10多分钟,这是不能 忍受的,在查看通Tomcat启动日志的时候发现:

org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of 
SecureRandom instance for session ID generation using [SHA1PRNG] took [253,251] milliseconds.

,通过查看日志,发现时间主要花在实例化 SecureRandom 对象上了。

原理解释

根本原因是 SecureRandom 这个 jre 的工具类的问题。那为什么 SecureRandom generateSeed 这么慢,甚至挂在 Linux 操作系统呢?

Tomcat 7/8 都使用 org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom 类产生安全随机类 SecureRandom 的实例作为会话 ID。

Tomcat 使用 SHA1PRNG 算法是基于 SHA-1 算法实现且保密性较强的伪随机数生成器。

在 SHA1PRNG 中,有一个种子产生器,它根据配置执行各种操作。

Linux 中的随机数可以从两个特殊的文件中产生,一个是 /dev/urandom,另外一个是 /dev/random。他们产生随机数的原理是利用当前系统的熵池来计算出固定一定数量的随机比特,然后将这些比特作为字节流返回。熵池就是当前系统的环境噪音,熵指的是一个系统的混乱程度&

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

g-Jack

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值