2019-04-28定时任务

每天晚上09点到12点运行 systemctl restart network 命令
每天上午7点到12点每2个小时和晚上22点运行 systemctl restart network 命令

每天晚上09点到12点运行 systemctl restart network 命令
00 21-00 * * * systemctl restart network ×

  • 21-00 * * * systemctl restart network ×
    00 21-23,00 * * * date >>/tmp/time.log √√√√√

每天上午7点到12点每2个小时和晚上22点运行 systemctl restart network 命令
00 7-12/2,22 * * * systemctl restart network

每天晚上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)" <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 
#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

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

  2. 这里 没有 :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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容