Tomcat问题汇总

Tomcat遇到的一些问题和解决方法:java

1. Tomcat慢启动问题
描述:
    
Tomcat启动有时耗时十几秒甚至达到一分多钟。缘由是Tomcat的
org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom类产生安全随机类SecureRandom的实例做为会话ID,随机数产生器会收集来自设备驱动器和其它源的环境噪声数据,并放入熵池中。产生器会评估熵池中的噪声数据的数量。当熵池为空时,这个噪声数据的收集是比较花时间的。这就意味着,Tomcat在生产环境中使用熵池时,会被阻塞较长的时间。
解决方法:
   
1)在Tomcat环境中解决。能够经过配置JRE使用非阻塞的Entropy Source。在catalina.sh中加入这么一行:-Djava.security.egd=file:/dev/./urandom 便可。
    2)在JVM环境中解决。打开$JAVA_PATH/jre/lib/security/java.security这个文件,找到下面的内容:
securerandom.source=file:/dev/urandom 替换成 securerandom.source=file:/dev/./urandom

2. NullPointerException和400错误
描述
    Tomcat运行一段时间后,会出现org.apache.coyote.http11.Http11Processor.service Error processing request java.lang.NullPointerException错误,localhost_access log中会出现400报错。缘由有待研究。
解决方法:
   
这个问题Tomcat官方说8.0已经修复了,可是我更新到8.5偶尔还会出现,8.0以前的作法是在server.xml中的Connector上添加useSendfile="false"便可,一样的作法也解决了我这个问题。apache

相关文章
相关标签/搜索