定时任务详解
1.每天晚上09点到12点运行 systemctl restart network 命令
00 21-23,00 * * * systemctl restart network
2.每天上午7点到12点每2个小时和晚上22点运行 systemctl restart network 命令
00 07-12/2,22 * * * systemctl restart nerwork
每天晚上12点 打包备份/etc/目录到/tmp下面
第1个里程碑-命令行测试 (测试命令是否ok)
第2个里程碑-书写脚本并测试脚本
第3个里程碑-写入定时任务 每分钟执行 检查
第4个里程碑-写入定时任务 根据要求修改时间
第1个里程碑-命令行测试 (测试命令是否ok)
[root@oldboyedu59 ~]#
[root@oldboyedu59 ~]# tar zcf /tmp/etc.tar.gz /etc/
tar: Removing leading `/' from member names
[root@oldboyedu59 ~]# date +%F
2019-04-28
[root@oldboyedu59 ~]# tar zcf /tmp/etc-$(date +%F).tar.gz /etc/
tar: Removing leading `/' from member names
[root@oldboyedu59 ~]# tar xf /tmp/etc-2019-04-28.tar.gz -C /opt/
第2个里程碑-书写脚本并测试脚本
书写脚本
[root@oldboyedu59 ~]# mkdir -p /server/scripts
[root@oldboyedu59 ~]# cat /server/scripts/bak-etc.sh
#!/bin/bash
tar zcf /tmp/etc-$(date +%F).tar.gz /etc/
测试脚本
[root@oldboyedu59 ~]# sh /server/scripts/bak-etc.sh
tar: Removing leading `/' from member names
[root@oldboyedu59 ~]# ll /tmp/etc-2019-04-28.tar.gz
-rw-r--r-- 1 root root 10212309 Apr 28 09:52 /tmp/etc-2019-04-28.tar.gz
第3个里程碑-写入定时任务 每分钟 检查
[root@oldboyedu59 ~]# crontab -l
#backup /etc/ to /tmp by liyy at 20190101
* * * * * sh /server/scripts/bak-etc.sh
检查流程
1.看日志
2.看结果
第4个里程碑-写入定时任务 根据要求修改时间
[root@oldboyedu59 ~]# crontab -l
#show time by liyy at 20190101
#*/2 * * * * date >>/tmp/time.log
#
#00 21-23,00 * * * date >>/tmp/time.log
#backup /etc/ to /tmp by liyy at 20190101
00 00 * * * sh /server/scripts/bak-etc.sh
在定时任务里面 每个命令或脚本 定向到空 或追加到文件
定时任务中 命令或脚本 输出信息
预备姿势
/dev/null 定向到黑洞
>/dev/null 2>/dev/null 正确的信息 错误信息 定向到黑洞中
>/dev/null 2>&1 正确的信息 错误信息 定向到黑洞中
&>/dev/null 正确的信息 错误信息 定向到黑洞中
追加到文件
>>/tmp/cron.log 2>&1 正确的信息 错误信息 定向到黑洞中
写法
[root@oldboyedu59 ~]# crontab -e
#show time by liyy at 20190101
#*/2 * * * * date >>/tmp/time.log 2>&1
#* * * * * date +\%F_\%w >>/tmp/time.log 2>&1
#
#00 21-23,00 * * * date >>/tmp/time.log 2>&1
#backup /etc/ to /tmp by liyy at 20190101
00 00 * * * sh /server/scripts/bak-etc.sh >/dev/null 2>&1
原因
如果不定向到空或追加到文件
定时任务会以邮件的形式把 输出到屏幕的内容 发给你
企业故障案例:定时任务没有定向到空或追加到文件的故障
1.系统邮件服务开启
>你就会不断收到邮件
You hava new mail in /var/spool/mail/root
2.系统邮件服务关闭(大部分情况)
把没有发送出去的邮件 临时放起来
/var/spool/postfix/maildrop (这个目录下面会有大量的小文件)
inode满了
【故障演示】:You hava new mail in /var/spool/mail/root
邮件服务开启的时候
crontab -l
#print xxxx
* * * * * echo {1..100}
邮箱内容
Received: by oldboyedu59.localdomain (Postfix, from userid 0)
id 58C33405A0A6; Sun, 28 Apr 2019 11:28:01 +0800 (CST)
From: "(Cron Daemon)"
To: [email protected]
Subject: Cron echo {1..100}
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env:
X-Cron-Env:
X-Cron-Env:
X-Cron-Env:
X-Cron-Env:
X-Cron-Env:
X-Cron-Env:
X-Cron-Env:
Message-Id: <[email protected]>
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
#show cron errors by liyy at 20190101
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
* * * * * dae
查看日志
[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
[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
解决方案:定向到空或追加到文件
每分钟 显示当前系统的时间和ip地址 追加到 /tmp/ip.log中
date
ip a s eth0
[root@oldboy59 scripts]# cat /tmp/ip.log
time:Sun Apr 28 12:02:01 CST 2019
ip: 10.0.0.200
[root@oldboy59 scripts]# cat ip.sh
echo time:`date`
echo ip: `/usr/sbin/ip a s eth0|awk -F"[ /]+" 'NR==3{print $3}'`
[root@oldboy59 scripts]# crontab -l |tail -1
* * * * * sh /server/scripts/ip.sh >>/tmp/ip.log 2>&1
[root@oldboy59 scripts]# cat /tmp/ip.log
time:Sun Apr 28 12:02:01 CST 2019
ip: 10.0.0.200
[root@oldboy59 scripts]#
执行: ls
1.系统会在PATH里面进行查找
[root@oldboyedu59 ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
- 这里面的路径中有 :命令解释器bash 执行
- 这里 没有 :command not found
基础:
每天晚上12点打包备份/etc/目录到/tmp下面
每天晚上12点打包备份/etc/目录到/backup 删除7天之前的备份
【面试题】定时任务
https://www.jianshu.com/p/d902ef6d3cf5
挑战:
1.每天晚上12点打包备份/etc/目录到/backup 删除7天之前的备份 但是要保留每周1的备份
终极挑战:
1.每天晚上12点打包备份/etc/目录到/backup/ip地址命名目录 删除7天之前的备份 但是要保留每周1的备份
/backup/10.0.0.200
下次磁盘管理:
磁盘分区 mbr
命令
今日提示集合:
"/etc/sudoers.tmp" 125L, 4588C written
/etc/sudoers: syntax error near line 105 <<<
语法错误 在105行
[sudo] password for oldboy:
Sorry, user oldboy may not run sudo on oldboyedu59.
[root@oldboyedu59 ~]# crontab -l
no crontab for root
root用户没有定时任务
2.no crontab for root - using an empty one
root用户没有定时任务 创建1个空的文件
3.crontab: installing new crontab
更新定时任务规则
mei liangfenzhong xianshi xitong shijian zhuijiadao /tmp/oldboy.txt
- /1 * * * date >>/tmp/oldboy.txt
"/tmp/crontab.5UZIdI" 3L, 115C written
crontab: installing new crontab
"/tmp/crontab.5UZIdI":3: bad hour
errors in crontab file, can't install.
Do you want to retry the same edit?
*/1 * * * * date >>/tmp/oldboy.txt
You have new mail in /var/spool/mail/root
你有1个新邮件 在/var/spool/mail/root