我最近在Debian 9以及Ubuntu 16.04 LTS上遇到过这个问题两次。
在使用 Tomcat 8和openjdk 8(未更改默认配置)重新安装操作系统后,重启几次后,Tomcat服务器在端口8080上停止响应。
服务器仍然在监听端口,但即使是简单的GET /
也会永远挂起:
# netstat -an|grep 8080
tcp6 0 0 :::8080 :::* LISTEN
# wget http://127.0.0.1:8080/
--2017-11-03 13:19:52-- http://127.0.0.1:8080/
Connecting to 127.0.0.1:8080... connected.
HTTP request sent, awaiting response...
根据线程转储,Tomcat似乎在启动时挂起:
"localhost-startStop-1" #14 daemon prio=5 os_prio=0 tid=0x00000000018a1000 nid=0x68d8 runnable [0x00007f2badacd000]
java.lang.Thread.State: RUNNABLE
at java.io.FileInputStream.readBytes(Native Method)
at java.io.FileInputStream.read(FileInputStream.java:255)
at sun.security.provider.SeedGenerator$URLSeedGenerator.getSeedBytes(SeedGenerator.java:539)
at sun.security.provider.SeedGenerator.generateSeed(SeedGenerator.java:144)
at sun.security.provider.SecureRandom$SeederHolder.<clinit>(SecureRandom.java:203)
at sun.security.provider.SecureRandom.engineNextBytes(SecureRandom.java:221)
- locked <0x00000000f99155c0> (a sun.security.provider.SecureRandom)
at java.security.SecureRandom.nextBytes(SecureRandom.java:468)
at java.security.SecureRandom.next(SecureRandom.java:491)
at java.util.Random.nextInt(Random.java:329)
at org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom(SessionIdGeneratorBase.java:237)
at org.apache.catalina.util.SessionIdGeneratorBase.getRandomBytes(SessionIdGeneratorBase.java:174)
at org.apache.catalina.util.StandardSessionIdGenerator.generateSessionId(StandardSessionIdGenerator.java:34)
at org.apache.catalina.util.SessionIdGeneratorBase.generateSessionId(SessionIdGeneratorBase.java:167)
at org.apache.catalina.util.SessionIdGeneratorBase.startInternal(SessionIdGeneratorBase.java:256)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:147)
- locked <0x00000000f9905808> (a org.apache.catalina.util.StandardSessionIdGenerator)
为什么会发生这种情况以及如何解决?
答案 0 :(得分:3)
基于Debian的发行版的OpenJDK 8附带/dev/random
预先配置为熵的来源。
如果没有足够的熵,/dev/random
将会阻止。
解决方案1:(首选)
安装haveged,它是一个可以产生额外熵的守护进程。
解决方案2:(可能不太安全)
将/usr/lib/jvm/default-java/jre/lib/security/java.security
更改为使用/dev/urandom
代替:
#securerandom.source=file:/dev/random
securerandom.source=file:/dev/./urandom
这将全局适用于所有Java进程。
或者,在-Djava.security.egd=file:/dev/./urandom
中将JAVA_OPTS
添加到/etc/default/tomcat8
(仅适用于Tomcat进程)。