Tomcat 服务频繁崩溃的排查方法

Tomcat 服务频繁崩溃排查方法

当Tomcat服务频繁崩溃时,可以按照以下步骤进行系统化排查:

1. 检查日志文件

**关键日志位置**:

  • `catalina.out` (标准输出和错误)

  • `catalina.log` (主日志)

  • `localhost.log` (应用相关日志)

  • `host-manager.log` 和 `manager.log` (管理相关日志)

**重点关注**:

  • 崩溃前的错误堆栈(Stack Trace)

  • OutOfMemoryError 或其他内存相关错误

  • 线程死锁(Deadlock)信息

  • 频繁的GC日志

2. 内存问题排查

**常见内存问题**:

  • 堆内存溢出(Java heap space)

  • 永久代/元空间溢出(PermGen/Metaspace)

  • 栈溢出(StackOverflowError)

  • 直接内存溢出(Direct buffer memory)

**排查工具**:

  • 在启动脚本中添加JVM参数:

```

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/path/to/dump.hprof

```

  • 使用`jmap`生成堆转储:

```bash

jmap -dump:format=b,file=/path/to/dump.hprof <pid>

```

  • 使用`jstat`监控内存使用:

```bash

jstat -gcutil <pid> 1000

```

3. 线程问题排查

**检查线程状态**:

```bash

jstack <pid> > thread_dump.txt

```

分析线程转储文件,查找:

  • 死锁(deadlock)

  • 大量线程阻塞(blocked)

  • 线程卡在相同代码位置

4. 资源泄漏检查

**常见泄漏源**:

  • 数据库连接未关闭

  • 文件流未关闭

  • 静态集合持续增长

  • 缓存未设置上限

**排查方法**:

  • 使用`jmap -histo:live <pid>`查看对象分布

  • 使用VisualVM或MAT分析堆转储

5. 系统资源检查

```bash

检查系统内存

free -m

检查打开文件限制

ulimit -a

检查进程资源使用

top -p <pid>

```

6. 配置检查

**关键配置项**:

  • `server.xml`中的连接器(Connector)配置

  • 线程池配置

  • JVM内存参数(Xms, Xmx, PermSize/MetaspaceSize)

  • 检查是否有过多的web应用部署

7. 监控工具

  • **VisualVM**:图形化监控JVM状态

  • **JConsole**:JMX监控工具

  • **Prometheus + Grafana**:建立长期监控

  • **APM工具**:如SkyWalking, Pinpoint等

8. 常见解决方案

  1. **内存不足**:
  • 增加JVM堆大小(-Xms, -Xmx)

  • 调整新生代/老年代比例(-XX:NewRatio)

  • 增加元空间大小(-XX:MetaspaceSize)

  1. **线程问题**:
  • 调整线程池大小(maxThreads)

  • 优化代码避免死锁

  • 减少同步块范围

  1. **资源泄漏**:
  • 确保所有资源正确关闭

  • 使用try-with-resources语句

  • 限制缓存大小

  1. **系统限制**:
  • 增加最大文件描述符数

  • 调整系统内核参数

9. 高级排查

对于难以复现的问题:

  • 启用飞行记录(JFR):`-XX:+FlightRecorder`

  • 使用async-profiler进行性能分析

  • 考虑使用商业分析工具如YourKit

通过以上系统化排查,通常可以定位到Tomcat频繁崩溃的根本原因。

相关推荐
Miraitowa_cheems21 分钟前
LeetCode算法日记 - Day 11: 寻找峰值、山脉数组的峰顶索引
java·算法·leetcode
海梨花27 分钟前
【从零开始学习Redis】项目实战-黑马点评D2
java·数据库·redis·后端·缓存
共享家952727 分钟前
linux-高级IO(上)
java·linux·服务器
橘子郡12334 分钟前
观察者模式和发布订阅模式对比,Java示例
java
指针满天飞35 分钟前
Collections.synchronizedList是如何将List变为线程安全的
java·数据结构·list
Java技术小馆36 分钟前
重构 Controller 的 7 个黄金法则
java·后端·面试
金銀銅鐵1 小时前
[Java] 以 IntStream 为例,浅析 Stream 的实现
java·后端
曳渔2 小时前
UDP/TCP套接字编程简单实战指南
java·开发语言·网络·网络协议·tcp/ip·udp
hqxstudying2 小时前
JAVA项目中邮件发送功能
java·开发语言·python·邮件
最初的↘那颗心3 小时前
Java HashMap深度解析:原理、实现与最佳实践
java·开发语言·面试·hashmap·八股文