• 定时任务不执行处理一例


    运维同事报告有北辰教育局的定时备份任务没有执行成功,让我进行检查


    vi /var/log/cron
    Jul  4 22:00:01 CentOSdslxTKZYK172 CROND[28155]: (root) CMD (/usr/local/sphinx_sh/csft_wkds.sh > /dev/null 2>&1)
    Jul  4 22:00:01 CentOSdslxTKZYK172 CROND[28118]: (root) CMD ( /usr/bin/python3 /usr/local/software/CloudPlatformUtil/BackupAll/Backup.py)
    Jul  4 22:00:01 CentOSdslxTKZYK172 CROND[28158]: (root) CMD (/usr/local/sphinx_sh/csft_bbs_post.sh > /dev/null 2>&1)


    如果crontab不重定向输出,并且crontab所执行的命令有输出内容的话,是一件非常危险的事情。因为该输出内容会以邮件的形式发送给用户,内容存储在邮件文件
    /var/spool/mail/$user
    如果命令执行比较频繁(如每分钟一次),或者命令输出内容较多,会使这个邮件文件不断追加内容,文件越来越大。而邮件文件一般存放在根分区,根分区一般相对较小,所以会造成根分区写满而无法登录服务器。
    所以在添加crontab命令时,无论命令是否有输出,最好都加上输出重定向到文件或者/dev/null中。如下
    */5 * * * * /root/XXXX.sh &>/dev/null 2>&1

    /dev/null 代表空设备文件
    > 代表重定向到哪里,例如:echo "123" > /home/123.txt
    1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null"
    2 表示stderr标准错误
    & 表示等同于的意思,2>&1,表示2的输出重定向等同于1

    那么>/dev/null 2>&1的意思就是:
    标准输出重定向到空设备文件,也就是不输出任何信息到终端,标准错误输出重定向等同于标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。

  • 相关阅读:
    数据结构算法练习(一)
    crontab详解
    git遇到问题
    docker容器管理
    docker及服务器遇到的坑
    shell study
    低级终端IO
    高级IO
    信号处理
    UNIX日期与时间
  • 原文地址:https://www.cnblogs.com/littlehb/p/11137708.html
Copyright © 2020-2023  润新知