问题

在一台单点机器部署完成且运行一段时间后,发现页面接口报错,登上机器发现磁盘满了。通过du -lh --max-depth=1du -sh * 找出是哪个文件。

发现是 项目中 stdout.log 文件过大,已经增加到了30多个G。

解决

使用 crontab定时执行清空stdout.log文件的命令。

  1. 准备一个 emptystdlog.sh 文件

    1
    touch emptystdlog.sh
  2. 文件写入以下内容

    1
    2
    #!/bin/bash
    echo "" > /root/work/output/stdout.log;
  3. 使用crontab -e 每天定时执行一次

    1
    0 0 * * * /bin/bash -x /root/work/output/emptystdlog.sh > /dev/null 2>&1
  4. 查看 crontab使用情况

    1
    crontable -l
  5. 编辑或删除定时任务

    1
    crontable -e

总结

这不是解决这个问题的好办法,应该通过设置 logback-spring.xml 文件来控制 stdout.log 文件