2019-04-28定時(shí)任務(wù)

每天晚上09點(diǎn)到12點(diǎn)運(yùn)行 systemctl restart network 命令
每天上午7點(diǎn)到12點(diǎn)每2個(gè)小時(shí)和晚上22點(diǎn)運(yùn)行 systemctl restart network 命令

每天晚上09點(diǎn)到12點(diǎn)運(yùn)行 systemctl restart network 命令
00 21-00 * * * systemctl restart network ×

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

每天上午7點(diǎn)到12點(diǎn)每2個(gè)小時(shí)和晚上22點(diǎn)運(yùn)行 systemctl restart network 命令
00 7-12/2,22 * * * systemctl restart network

每天晚上12點(diǎn) 打包備份/etc/目錄到/tmp下面

第1個(gè)里程碑-命令行測(cè)試 (測(cè)試命令是否ok)

第2個(gè)里程碑-書(shū)寫(xiě)腳本并測(cè)試腳本

第3個(gè)里程碑-寫(xiě)入定時(shí)任務(wù) 每分鐘執(zhí)行 檢查

第4個(gè)里程碑-寫(xiě)入定時(shí)任務(wù) 根據(jù)要求修改時(shí)間

第1個(gè)里程碑-命令行測(cè)試 (測(cè)試命令是否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個(gè)里程碑-書(shū)寫(xiě)腳本并測(cè)試腳本

書(shū)寫(xiě)腳本

[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/

測(cè)試腳本

[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個(gè)里程碑-寫(xiě)入定時(shí)任務(wù) 每分鐘 檢查

[root@oldboyedu59 ~]# crontab -l

backup /etc/ to /tmp by liyy at 20190101

          • sh /server/scripts/bak-etc.sh

檢查

1.看日志

2.看結(jié)果

第4個(gè)里程碑-寫(xiě)入定時(shí)任務(wù) 根據(jù)要求修改時(shí)間

[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

在定時(shí)任務(wù)里面 每個(gè)命令或腳本 定向到空 或追加到文件
定時(shí)任務(wù)中 命令或腳本 輸出信息

預(yù)備姿勢(shì)

    /dev/null 定向到黑洞 
    >/dev/null  2>/dev/null 正確的信息 錯(cuò)誤信息 定向到黑洞中 
    >/dev/null  2>&1        正確的信息 錯(cuò)誤信息 定向到黑洞中 
    &>/dev/null             正確的信息 錯(cuò)誤信息 定向到黑洞中 

    追加到文件 
    >>/tmp/cron.log   2>&1        正確的信息 錯(cuò)誤信息 定向到黑洞中 

寫(xiě)法

[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

原因

如果不定向到空或追加到文件
定時(shí)任務(wù)會(huì)以郵件的形式把 輸出到屏幕的內(nèi)容 發(fā)給你

企業(yè)故障案例:定時(shí)任務(wù)沒(méi)有定向到空或追加到文件的故障

1.系統(tǒng)郵件服務(wù)開(kāi)啟
你就會(huì)不斷收到郵件
You hava new mail in /var/spool/mail/root

2.系統(tǒng)郵件服務(wù)關(guān)閉(大部分情況)
把沒(méi)有發(fā)送出去的郵件 臨時(shí)放起來(lái)
/var/spool/postfix/maildrop (這個(gè)目錄下面會(huì)有大量的小文件)
inode滿(mǎn)了

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

郵件服務(wù)開(kāi)啟的時(shí)候

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

郵箱內(nèi)容

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

【故障演示】系統(tǒng)郵件服務(wù)關(guān)閉(大部分情況) 把沒(méi)有發(fā)送出去的郵件 臨時(shí)放起來(lái)

定時(shí)任務(wù)內(nèi)容:

此時(shí)定時(shí)任務(wù) 沒(méi)有定向到空或追加到文件

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 )

查看臨時(shí)目錄

可以發(fā)現(xiàn) 郵件臨時(shí)目錄有大量小文件
日積月累會(huì)導(dǎo)致占用系統(tǒng)大量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

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

每分鐘 顯示當(dāng)前系統(tǒng)的時(shí)間和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]#

執(zhí)行: ls
1.系統(tǒng)會(huì)在PATH里面進(jìn)行查找

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

  1. 這里面的路徑中有 :命令解釋器bash 執(zhí)行

  2. 這里 沒(méi)有 :command not found

基礎(chǔ):
每天晚上12點(diǎn)打包備份/etc/目錄到/tmp下面
每天晚上12點(diǎn)打包備份/etc/目錄到/backup 刪除7天之前的備份
【面試題】定時(shí)任務(wù)
http://www.itdecent.cn/p/d902ef6d3cf5

挑戰(zhàn):
1.每天晚上12點(diǎn)打包備份/etc/目錄到/backup 刪除7天之前的備份 但是要保留每周1的備份

終極挑戰(zhàn):
1.每天晚上12點(diǎn)打包備份/etc/目錄到/backup/ip地址命名目錄 刪除7天之前的備份 但是要保留每周1的備份
/backup/10.0.0.200

下次磁盤(pán)管理:

磁盤(pán)分區(qū) mbr
命令

今日提示集合:

"/etc/sudoers.tmp" 125L, 4588C written

/etc/sudoers: syntax error near line 105 <<<
語(yǔ)法錯(cuò)誤 在105行

[sudo] password for oldboy:
Sorry, user oldboy may not run sudo on oldboyedu59.

[root@oldboyedu59 ~]# crontab -l
no crontab for root
root用戶(hù)沒(méi)有定時(shí)任務(wù)

2.no crontab for root - using an empty one
root用戶(hù)沒(méi)有定時(shí)任務(wù) 創(chuàng)建1個(gè)空的文件

3.crontab: installing new crontab
更新定時(shí)任務(wù)規(guī)則

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個(gè)新郵件 在/var/spool/mail/root

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容