Tomcat遇到的一些问题和解决方法:
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/./urandom2. 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"即可,同样的做法也解决了我这个问题。