Tomcat日志占满磁盘怎么办?

手动删除日志文件

定位Tomcat日志目录

Tomcat日志通常位于安装目录下的 logs/ 子目录中,常见路径:

/opt/tomcat/logs/      # 默认安装路径
/usr/local/tomcat/logs/
/home/user/tomcat/logs/

使用命令进入目录:

cd /opt/tomcat/logs/  # 替换为你的实际路径

查看并删除日志文件

  • 查看日志文件列表:

    ls -lh *.log *.txt *.out

    主要文件包括:

    • catalina.out:主运行日志
    • localhost_access_log.*.txt:访问日志
    • catalina.yyyy-mm-dd.log:每日日志
  • 删除指定日志(例如清理30天前的访问日志):

    find . -name "localhost_access_log*.txt" -mtime +30 -exec rm -f {} \;
    • -mtime +30:修改时间超过30天的文件
    • -exec rm -f {} \;:强制删除匹配的文件
  • 清空正在写入的日志(如 catalina.out):

    > catalina.out  # 清空内容但保留文件(避免重启Tomcat)

自动清理方案(推荐)

使用 logrotate 工具

logrotate 是Linux自带的日志管理工具,可定时压缩、轮转和删除日志。
步骤:

  1. 创建配置文件:

    sudo nano /etc/logrotate.d/tomcat
  2. 写入以下配置(按需调整):

    /opt/tomcat/logs/catalina.out {
        daily          # 每天轮转
        rotate 7       # 保留7份旧日志
        compress       # 压缩旧日志
        delaycompress  # 延迟压缩(下次轮转时压缩)
        missingok      # 文件不存在时不报错
        notifempty     # 空文件不轮转
        copytruncate   # 复制后清空原文件(无需重启Tomcat)
    }
    /opt/tomcat/logs/localhost_access_log*.txt {
        monthly        # 每月轮转
        rotate 6       # 保留6个月
        compress
        missingok
    }
  3. 手动测试配置:

    sudo logrotate -f /etc/logrotate.d/tomcat

通过 cron 定时任务

定期执行清理脚本(例如每天凌晨2点):

  1. 创建脚本 /opt/scripts/clean_tomcat_logs.sh
    #!/bin/bash
    LOG_DIR="/opt/tomcat/logs"
    find $LOG_DIR -name "*.log" -mtime +15 -exec rm -f {} \;
    find $LOG_DIR -name "*.txt" -mtime +30 -exec rm -f {} \;
  2. 添加可执行权限:
    chmod +x /opt/scripts/clean_tomcat_logs.sh
  3. 加入cron计划:
    crontab -e

    添加行:

    0 2 * * * /opt/scripts/clean_tomcat_logs.sh

关键注意事项

  1. 避免直接删除正在写入的日志

    • 使用 > catalina.out 清空而非 rm,防止Tomcat因文件句柄丢失报错。
    • 若必须删除,先重启Tomcat:sudo systemctl restart tomcat
  2. 备份重要日志
    删除前确认日志无保留价值,必要时备份:

    cp catalina.out catalina_$(date +%F).backup
  3. 权限问题

    • 若提示权限不足,使用 sudo 或切换为Tomcat用户(通常为 tomcat):
      sudo -u tomcat find /opt/tomcat/logs/ -name "*.log" -mtime +30 -delete

最佳实践建议

  • 首选 logrotate:自动化管理更安全,避免手动误删。
  • 监控磁盘空间:设置告警(如 df -h 或工具如Nagios)。
  • 日志分级保留:访问日志保留30天,调试日志保留7天。
  • 生产环境慎用 rm -rf:误操作可能导致系统崩溃,建议先 ls 确认文件列表。

引用说明:本文方法基于Linux文件管理通用实践及Apache Tomcat官方文档。logrotate配置参考了Red Hat Enterprise Linux手册,cron用法遵循Linux标准定时任务规范,具体路径请根据实际Tomcat安装位置调整。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/8781.html

(0)
酷番叔酷番叔
上一篇 2025年7月26日 21:23
下一篇 2025年7月26日 21:47

相关推荐

  • 安全大数据如何赋能编组站高效运作?

    安全大数据对编组站的作用主要体现在提升作业效率、保障运输安全、优化资源配置以及辅助决策支持等多个维度,随着铁路运输规模的不断扩大和智能化转型的深入推进,编组站作为铁路网中的关键节点,其作业复杂性和安全风险日益凸显,安全大数据技术的应用,通过对海量多源数据的采集、分析与挖掘,为编组站的现代化管理提供了全新的技术支……

    2025年11月22日
    9900
  • 国内BI图表工具市场,竞争格局与未来发展走向如何?

    竞争激烈,多方并存,未来趋向AI智能化、实时化及低代码平民化,深化业务赋能。

    2026年3月4日
    4000
  • 安全数据库在数据安全与隐私保护中的核心挑战与研究热点是什么?

    随着数字化转型加速推进,数据已成为企业的核心资产与社会的关键生产要素,而数据库作为数据存储、管理与交互的核心载体,其安全性直接关系到个人隐私保护、企业商业机密维护乃至国家数据主权安全,近年来,全球范围内数据泄露事件频发,如2023年某跨国企业因数据库访问控制配置失误导致1.2亿用户敏感信息泄露,造成超10亿美元……

    2025年11月4日
    11200
  • 安全数据库系统推理问题如何有效防范与解决?

    随着数字化转型的深入,数据库系统已成为企业核心资产的关键载体,其安全性直接关系到个人隐私、商业机密乃至国家安全,在传统安全机制(如访问控制、数据加密)之外,一种隐蔽却威胁深重的风险——推理问题,逐渐成为安全数据库领域的研究焦点,推理攻击并非直接窃取数据,而是通过分析合法查询的返回结果,利用数据间的关联性间接推断……

    2025年11月12日
    10400
  • 如何退出CMD和系统安全模式?

    退出安全模式中的命令提示符窗口若您在Windows安全模式下打开了命令提示符(如通过“带命令提示符的安全模式”启动),只需关闭CMD窗口:在命令提示符窗口中输入 exit 并按回车键,窗口将立即关闭,但系统仍处于安全模式,返回桌面后,按 Win + R 打开运行框,输入 msconfig 并回车,进入下一步操作……

    2025年7月2日
    15600

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信