/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 日志爆盘。

🎉 问题解决!

相关推荐
鲨莎分不晴4 小时前
Apache Flume 入门到实战:构建可靠的大数据采集管道
大数据·apache·flume
温暖小土6 小时前
ClickHouse vs Apache Doris:2026年实时OLAP数据库选型深度解析
数据库·数据仓库·clickhouse·apache
小当家.1058 小时前
《Java操作Excel实战教程:Apache POI从入门到精通》
java·apache·excel
计算机毕设指导69 小时前
基于微信小程序的社区医疗服务管理系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea
Gobysec10 小时前
Goby 漏洞安全通告|Apache Struts XWork 组件 XML外部实体注入漏洞(CVE-2025-68493)
struts·安全·apache
仙俊红10 小时前
一次 Web 请求,服务器到底能看到什么?
服务器·前端·firefox
坚持学习前端日记10 小时前
学校管理系统 ER图
java·运维·服务器·mysql·apache
zhojiew10 小时前
Kafka Connect集成Apache Iceberg写入AWS Glue表
kafka·apache·aws
程序员老徐19 小时前
Tomcat源码分析三(Tomcat请求源码分析)
java·tomcat
firstacui1 天前
Keepalived+nginx+tomcat
nginx·tomcat·firefox