Debian linux Tomcat 8全新安装没有响应端口8080

时间:2017-11-03 13:47:51

标签: java linux tomcat

我最近在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)

为什么会发生这种情况以及如何解决?

1 个答案:

答案 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进程)。