原来tomcat启动很快,突然有一天,不知道什么原因,tomcat启动非常慢,要花5~6分钟,甚至更久。
Apr 24, 2018 10:26:01 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://www.springframework.org/tags is already defined
Apr 24, 2018 10:26:01 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://www.springframework.org/tags/form is already defined
Configuring Shiro ...
Shiro Configured
Apr 24, 2018 10:31:42 PM org.apache.catalina.util.SessionIdGenerator createSecureRandom
INFO: Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [308,521] milliseconds.
Apr 24, 2018 10:31:43 PM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory /var/lib/tomcat7/webapps/ROOT
Apr 24, 2018 10:31:44 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-80"]
Apr 24, 2018 10:31:44 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 361981 ms
以下是在网上找到的解决方案
解决方法
- 在catalina.sh,JAVA_OPTS参数中加上
-Djava.security.egd=file:/dev/./urandom
- 找到$JAVA_PATH/jre/lib/security/java.security这个文件,将securerandom.source值替换为file:/dev/./urandom
securerandom.source=file:/dev/./urandom
tomcat变慢的原因
Tomcat 7/8都使用org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom类产生安全随机类SecureRandom的实例作为会话ID,启动的时间就耗费在这里了。
-
如果Java.security.egd 属性或securerandom.source属性指定的是”file:/dev/random”或”file:/dev/urandom”,那么JVM 会使用本地种子产生器NativeSeedGenerator,它会调用super()方法,即调用 SeedGenerator.URLSeedGenerator(/dev/random)方法进行初始化。
-
如果java.security.egd属性或securerandom.source属性指定的是其它已存在的URL,那么会调用SeedGenerator.URLSeedGenerator(url)方法进行初始化。
在产生回话id时,产生器会评估熵池(entropy pool)中的噪声数量。随机数是从熵池中进行创建的。
如果将熵池设置为/dev/random或/dev/urandom,会直接返回熵池中噪声的随机字节。
当熵池为空时,来自/dev/random的读操作将被阻塞,直到熵池收集到足够的环境噪声数据。这么做的目的是成为一个密码安全的伪随机数发生器,熵池要有尽可能大的输出。
什么是环境噪声?
随机数产生器会收集来自设备驱动器和其它源的环境噪声数据,并放入熵池中。产生器会评估熵池中的噪声数据的数量。当熵池为空时,这个噪声数据的收集是比较花时间的。这就意味着,Tomcat在生产环境中使用熵池时,会被阻塞较长的时间。
网友评论