第五周-day25-定时任务补充

《第五周-day25-定时任务补充》 五一前-day25-定时任务补充.png

一、特殊符号:

*  每 的意思
/  每隔xx
-  范围 连续区间 1-10
,  不连续的 没有规律的

 /n n是数字
n代表自然数字,即“每隔n单位时间”,例如:每10分钟执行一次任务可以写成

二、每天晚上12点,打包备份/etc/目录到/tmp/下面

[图片上传中…(image.png-3d4bc5-1556954690391-0)]

点击此链接 定时任务书写格式—运维大神必会的专业书写步骤

/server/scripts/bak-etc.sh 把目录创建到这里

1.第一步:命令行测试(测试命令是否ok)
2.第二步:书写脚本并测试脚本
3.第三步:写入定时任务—检查
4.第四步:写入定时任务—根据要求修改为规定时间
1.第一步:命令行测试(测试命令是否ok)

《第五周-day25-定时任务补充》 第一步:命令行测试(测试命令是否ok)

2.第二步:书写脚本并测试脚本

《第五周-day25-定时任务补充》 第二步:书写脚本并测试脚本(在+%F后加一个%M)

3.第三步:写入定时任务—检查

为了避免写完脚本去添加执行权限,可以用 sh执行脚本
sh   /server/scripts/bak-etc.sh

《第五周-day25-定时任务补充》 第三步:写入定时任务—检查
《第五周-day25-定时任务补充》 看日志 看结果

4.第四步:写入定时任务—根据要求修改为规定时间

《第五周-day25-定时任务补充》 根据要求修改为规定时间

三、书写脚本排错

sh -x
带+号的就是脚本执行的过程

《第五周-day25-定时任务补充》 image.png

四、定时任务箴言(坑)

1.一定要加上1个注释说明

2.书写定时任务的时候 尽量用脚本

3.运行脚本使用sh

4.定时任务中%有特殊含义,date +%F_%w 需要加\

5.在定时任务中命令的脚本 使用绝对路径

用户的定时任务   用户家目录
系统的定时任务   根下

6.最坑

在定时任务里面 每个命令或脚本 定向到空 或追加到文件
1.预备姿势
    定向到空   /dev/null  黑洞   定向到黑洞
        >/dev/null 2>/dev/null  正确信息 错误信息都定向到黑洞中
        >/dev/null  2>&1  正确信息 错误信息都定向到黑洞中
        &>/dev/null  正确信息 错误信息都定向到黑洞中
    
2.追加到文件
        >>/tmp/cron.log  2>&1 正确信息 错误信息都定向到文件中

不能同时 ,要么追加到文件,要么定向到空

为什么要定向到空或追加到文件呢?原因是什么:

如果不定向到空或追加到文件
定时任务会以邮件的形式把 输出到屏幕的内容 发给你

《第五周-day25-定时任务补充》 定向到空和追加到文件

企业故障案例:定时任务没有定向到空或追加到文件的故障

1.系统邮件服务开启
你就会不断收到邮件 
You hava new mail in /var/spool/mail/root
2.系统邮件服务关闭(大部分情况)
systemctl disable pastfix   \\重启服务器后永久关闭邮箱

把没有发送出去的邮件 临时放起来 
/var/spool/postfix/maildrop  (这个目录下面会有大量的小文件)
如果定时任务很多,时间久了,inode就会满了

【故障演示】:You hava new mail in /var/spool/mail/root

邮件服务开启的时候

crontab -l 
#print xxxx
* * * * * echo {1..100}

邮箱内容
tail

Received: by oldboyedu59.localdomain (Postfix, from userid 0)
        id 58C33405A0A6; Sun, 28 Apr 2019 11:28:01 +0800 (CST)
From: "(Cron Daemon)" <root@oldboyedu59.localdomain>
To: root@oldboyedu59.localdomain
Subject: Cron <root@oldboyedu59> echo {1..100} 
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env: <XDG_SESSION_ID=79>
X-Cron-Env: <XDG_RUNTIME_DIR=/run/user/0>
X-Cron-Env: <LANG=en_US.utf8>
X-Cron-Env: <SHELL=/bin/sh>
X-Cron-Env: <HOME=/root>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=root>
X-Cron-Env: <USER=root>
Message-Id: <20190428032801.58C33405A0A6@oldboyedu59.localdomain>
Date: Sun, 28 Apr 2019 11:28:01 +0800 (CST)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84  85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100

【故障演示】系统邮件服务关闭(大部分情况) 把没有发送出去的邮件 临时放起来

定时任务内容:

此时定时任务 没有定向到空或追加到文件

crontab -l     写入了一个错误的命令dae900次
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 

查看日志 《第五周-day25-定时任务补充》 image.png

[root@oldboyedu59 ~]# tail /var/log/cron 
Apr 28 11:48:34 oldboyedu59 CROND[32067]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32068]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32069]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32070]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32071]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32072]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32066]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32063]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32064]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32065]: (root) CMD (dae )

查看临时目录

可以发现 邮件临时目录有大量小文件
日积月累会导致占用系统大量inode

ll /var/spool/postfix/maildrop  \\查看所有邮件
[root@oldboyedu59 ~]# ll /var/spool/postfix/maildrop/|head -20
total 7208
-rwxr--r-- 1 root postdrop 447 Apr 28 11:48 003888026AC0
-rwxr--r-- 1 root postdrop 525 Apr 28 11:48 004DA8024270
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0054D801F68B
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 005728025B34
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0071F80268C6
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0083C801F4DE
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0084C8024D3B
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 00BDD8024F7E
-rwxr--r-- 1 root postdrop 526 Apr 28 11:48 00CB9802640D
-rwxr--r-- 1 root postdrop 525 Apr 28 11:48 00D0D8024006
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 00D1280253E9
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 00F4E80258F3
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0164480253EA
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 018518026AC1
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 018BA802662F
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 019B08024F7F
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 01A45801F4DF
-rwxr--r-- 1 root postdrop 526 Apr 28 11:48 01B0B8025FAB
-rwxr--r-- 1 root postdrop 526 Apr 28 11:48 01BE680261D3

解决方案:定向到空或追加到文件

7.最后是定时任务运行脚本环境变量问题

定时任务运行脚本的时候 只识别/usr/bin/和/bin/下面的命令

[root@oldboyedu59 ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

1.系统会在PATH里面进行查找

  1. 这里面的路径中有 :命令解释器bash 执行

  2. 这里 没有 :command not found

解决
使用命令用绝对路径
脚本开头 重新设置$PATH
. /etc/profile 或 source /etc/profile

小任务:
 每天晚上12点打包备份/etc/目录到/tmp下面
 每天晚上12点打包备份/etc/目录到/tmp下面 删除7天之前的备份
 
 1.每天晚上12点打包备份/etc/目录到/tmp下面 删除7天之前的备份,但是保留每周一的不删除
 
 2.每天晚上12点打包备份/etc/目录到/backup/ip(地址命名目录) 删除7天之前的备份,但是保留每周一的不删除
 
【面试题】定时任务
https://www.jianshu.com/p/d902ef6d3cf5
定时任务补充:

检查程序是否开机自启动和是否正在运行

a.检查crond程序当前是否运行:

1.ps -ef|grep crond

2.systemctl is-active crond
active

b.定时任务是否开机自启动:

systemctl is-enabled crond
enabled

rsyslog:自动写系统日志的文件

确保rsyslog 是否运行  system log
[10:09 root@oldboy ~]# systemctl  is-enabled rsyslog  
enabled
[10:10 root@oldboy ~]# systemctl is-active  rsyslog
active

未完待续……

    原文作者:linux丶晨星
    原文地址: https://www.jianshu.com/p/acc416bcb0a5
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞