1. Tomcat启动失败
原因:可能由配置错误(如server.xml语法问题)、内存不足(JVM堆内存过小)、依赖缺失(缺少JAR包)、端口冲突或环境变量(JAVA_HOME/CATALINA_HOME未配置)导致。
解决方法:
tail -f /var/log/tomcat/catalina.out(或/opt/tomcat/logs/catalina.out)查看详细错误信息,这是解决启动问题的核心步骤。netstat -tuln | grep 8080(默认端口)查看端口是否被占用,若被占用可通过kill -9 <PID>结束占用进程,或在server.xml中修改<Connector>标签的port属性(如改为8081)。/etc/environment或~/.bashrc中添加JAVA_HOME=/usr/lib/jvm/default-java(根据实际JDK路径调整)、CATALINA_HOME=/opt/tomcat(Tomcat安装路径),执行source /etc/environment使配置生效。catalina.sh(或/etc/default/tomcat),增加JAVA_OPTS设置(如-Xms512m -Xmx1024m,分别表示初始堆内存512MB、最大堆内存1024MB),避免内存不足导致启动失败。2. 日志乱码(控制台/请求参数)
原因:Tomcat默认日志编码(如GBK)与系统或应用编码(如UTF-8)不一致,或请求参数未指定编码。
解决方法:
conf/logging.properties,将java.util.logging.ConsoleHandler.encoding的值从GBK改为UTF-8,保存后重启Tomcat。server.xml的<Connector>标签中添加URIEncoding="UTF-8"(如<Connector port="8080" protocol="HTTP/1.1" URIEncoding="UTF-8" .../>),确保请求参数正确解码。request.setCharacterEncoding("UTF-8")(如Servlet的doPost方法中),强制应用使用UTF-8编码处理请求。3. 无法访问Tomcat管理页面
原因:tomcat-users.xml未配置管理用户角色,或防火墙阻止了访问。
解决方法:
conf/tomcat-users.xml,添加带有manager-gui(管理界面)和admin-gui(管理员)角色的用户,例如:<tomcat-users>
<user username="admin" password="yourpassword" roles="manager-gui,admin-gui"/>
</tomcat-users>
保存后重启Tomcat。sudo ufw allow 8080(默认端口)开放Tomcat端口,允许外部访问。4. 内存溢出(OutOfMemoryError)
原因:JVM堆内存、元空间(Metaspace)不足,或应用程序存在内存泄漏(如未释放的对象)。
解决方法:
catalina.sh,增大-Xmx(最大堆内存,如2048m)和-Xms(初始堆内存,如1024m)的值;对于Java 8及以上版本,添加-XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m(元空间大小)。JAVA_OPTS中添加-XX:+UseG1GC(使用G1垃圾回收器,适用于大内存应用),提升垃圾回收效率。jmap -dump:format=b,file=heap.hprof <PID>生成),定位未释放的对象(如静态集合、未关闭的数据库连接),修复代码中的内存泄漏点。5. 文件/目录权限问题
原因:Tomcat用户(通常为tomcat)对logs、work、webapps等目录没有读写权限。
解决方法:
sudo chown -R tomcat:tomcat /opt/tomcat(Tomcat安装路径)将目录所有者改为tomcat用户和组。sudo chmod -R 755 /opt/tomcat赋予目录读写执行权限(755表示所有者有全部权限,组和其他用户有读和执行权限),确保Tomcat能正常访问和写入文件。6. 端口冲突
原因:Tomcat使用的端口(如8080、8005、8009)被其他进程(如Nginx、Apache)占用。
解决方法:
netstat -tuln | grep <端口号>(如netstat -tuln | grep 8080)查看占用进程的PID。sudo kill -9 <PID>终止进程。conf/server.xml,修改<Connector>标签的port属性(如将8080改为8081),保存后重启Tomcat。7. JDK版本不符
原因:Tomcat版本与JDK版本不兼容(如Tomcat 10需要JDK 11及以上,Tomcat 9需要JDK 8及以上)。
解决方法:
java -version查看当前JDK版本,确保符合Tomcat的要求(参考Tomcat官网兼容性列表)。sudo apt-get install openjdk-11-jdk(Debian默认仓库)或下载Oracle JDK安装包安装,然后配置JAVA_HOME环境变量指向JDK安装路径。