/usr/local/apache-tomcat-9.0.71/logs/catalina.out占用了118G

找到了!真正的"空间黑洞"就是:

📁 **/usr/local/apache-tomcat-9.0.71/logs/catalina.out ------ **一个 118GB 的 Tomcat 日志文件!

这是非常典型的 Tomcat 日志未轮转导致磁盘爆满 的问题。


✅ 立即释放空间:清空 catalina.out

🔥 安全清空日志(不中断 Tomcat 服务):

bash 复制代码
> /usr/local/apache-tomcat-9.0.71/logs/catalina.out

✅ 这条命令会清空文件内容但保留文件句柄 ,Tomcat 进程可以继续写入,服务完全不受影响

或者(等效):

bash 复制代码
truncate -s 0 /usr/local/apache-tomcat-9.0.71/logs/catalina.out

📊 清理后验证

bash 复制代码
# 查看日志是否已清空
ls -lh /usr/local/apache-tomcat-9.0.71/logs/catalina.out

# 查看磁盘空间是否释放
df -h

你应该会看到:

  • catalina.out 大小变为 0
  • / 分区可用空间从 ~458M 增加到 100GB+

🔒 防止再次爆盘:配置 Tomcat 日志轮转

✅ 方法1:使用 logrotate(推荐)

创建配置文件:

bash 复制代码
cat > /etc/logrotate.d/tomcat <<EOF
/usr/local/apache-tomcat-9.0.71/logs/catalina.out {
    copytruncate
    daily
    rotate 7
    compress
    missingok
    size 100M
}
EOF
  • copytruncate:先复制日志再清空原文件,避免 Tomcat 写入中断
  • size 100M:当日志超过 100MB 就轮转
  • rotate 7:保留最近 7 个日志文件
  • compress:自动压缩旧日志(.gz)

✅ 方法2:禁用 catalina.out(可选)

如果你不需要标准输出日志,可以在 Tomcat 启动脚本中重定向到 /dev/null

编辑 bin/catalina.sh(不推荐直接改,建议通过 setenv.sh):

bash 复制代码
# 创建 setenv.sh(Tomcat 会自动加载)
echo 'CATALINA_OUT="/dev/null"' > /usr/local/apache-tomcat-9.0.71/bin/setenv.sh
chmod +x /usr/local/apache-tomcat-9.0.71/bin/setenv.sh

⚠️ 但这样会丢失 startup/shutdown 日志,一般建议用 logrotate 而非禁用


🧹 补充建议

  1. 检查其他日志文件

    bash 复制代码
    ls -lh /usr/local/apache-tomcat-9.0.71/logs/

    如果 localhost_access_log.*.txt 很大,也可考虑在 conf/server.xml 中关闭访问日志(或限制)。

  2. 重启 Tomcat(非必须)

    清空 catalina.out不需要重启 ,但如果你刚配置了 logrotate,可等一天看是否生效。

  3. 监控磁盘

    bash 复制代码
    # 添加一个 cron 每天检查
    echo "0 2 * * * df -h | mail -s 'Disk Usage' your@email.com" | crontab -

✅ 总结操作(复制粘贴即可)

bash 复制代码
# 1. 清空大日志
> /usr/local/apache-tomcat-9.0.71/logs/catalina.out

# 2. 配置自动轮转
cat > /etc/logrotate.d/tomcat <<EOF
/usr/local/apache-tomcat-9.0.71/logs/catalina.out {
    copytruncate
    daily
    rotate 7
    compress
    missingok
    size 100M
}
EOF

# 3. 验证
df -h
ls -lh /usr/local/apache-tomcat-9.0.71/logs/catalina.out

完成以上操作后,你的磁盘空间将立即释放 118GB+ ,系统恢复正常!

并且未来再也不会因 Tomcat 日志爆盘。

🎉 问题解决!

相关推荐
camellias_1 天前
【无标题】
java·tomcat
身如柳絮随风扬2 天前
Tomcat 体系结构
java·tomcat
卓怡学长2 天前
w1基于springboot高校学生评教系统
java·spring boot·tomcat·maven·intellij-idea
夕除2 天前
javaweb--02
java·tomcat
卓怡学长2 天前
m326数据结构课程网络学习平台的设计与实现+vue
java·spring·tomcat·maven·intellij-idea·mybatis
huanmieyaoseng10032 天前
Linux 安装配置 Tomcat超详细2026新(附安装包)
linux·运维·tomcat
Zhu7582 天前
【容器镜像打包】Apache Seatunnel打包容器镜像
apache
橘子编程2 天前
Hermes Agent 完整知识总结与使用教程
java·人工智能·ai·tomcat·maven·ai编程
卓怡学长3 天前
基于 SpringBoot 的生活信息分享平台,从 0 到 1 完整实现(附源码 + 数据库)
java·数据库·spring boot·tomcat·maven
Zhu7583 天前
【软件部署】用docker部署Apache Kafka 集群架构isolated模式带SSL
docker·kafka·apache