linux 例行性工作,鳥哥的 Linux 私房菜

15.2.2 實際運作單一工作排程

單一工作排程的進行就使用 at 這個指令囉!這個指令的運作非常簡單!將 at 加上一個時間即可!基本的語法如下:

[root@study ~]# at [-mldv] TIME

[root@study ~]# at -c 工作號碼

選項與參數:

-m :當 at 的工作完成後,即使沒有輸出訊息,亦以 email 通知使用者該工作已完成。

-l :at -l 相當於 atq,列出目前系統上面的所有該使用者的 at 排程;

-d :at -d 相當於 atrm ,可以取消一個在 at 排程中的工作;

-v :可以使用較明顯的時間格式列出 at 排程中的工作列表;

-c :可以列出後面接的該項工作的實際指令內容。

TIME:時間格式,這裡可以定義出『什麼時候要進行 at 這項工作』的時間,格式有:

HH:MMex> 04:00

在今日的 HH:MM 時刻進行,若該時刻已超過,則明天的 HH:MM 進行此工作。

HH:MM YYYY-MM-DDex> 04:00 2015-07-30

強制規定在某年某月的某一天的特殊時刻進行該工作!

HH:MM[am|pm] [Month] [Date]ex> 04pm July 30

也是一樣,強制在某年某月某日的某時刻進行!

HH:MM[am|pm] + number [minutes|hours|days|weeks]

ex> now + 5 minutesex> 04pm + 3 days

就是說,在某個時間點『再加幾個時間後』才進行。

老實說,這個 at 指令的下達最重要的地方在於『時間』的指定了!鳥哥喜歡使用『 now + ... 』

的方式來定義現在過多少時間再進行工作,但有時也需要定義特定的時間點來進行!底下的範例先看看囉!

範例一:再過五分鐘後,將 /root/.bashrc 寄給 root 自己

[root@study ~]# at now + 5 minutes <==記得單位要加 s 喔!

at> /bin/mail -s "testing at job" root < /root/.bashrc

at> <==這裡輸入 [ctrl] + d 就會出現 的字樣!代表結束!

job 2 at Thu Jul 30 19:35:00 2015

# 上面這行資訊在說明,第 2 個 at 工作將在 2015/07/30 的 19:35 進行!

# 而執行 at 會進入所謂的 at shell 環境,讓你下達多重指令等待運作!

範例二:將上述的第 2 項工作內容列出來查閱

[root@study ~]# at -c 2

#!/bin/sh <==就是透過 bash shell 的啦!

# atrun uid=0 gid=0

# mail root 0

umask 22

....(中間省略許多的環境變數項目)....

cd /etc/cron\.d || {

echo 'Execution directory inaccessible' >&2

exit 1

}

${SHELL:-/bin/sh} << 'marcinDELIMITER410efc26'

/bin/mail -s "testing at job" root < /root/.bashrc # 這一行最重要!

marcinDELIMITER410efc26

# 你可以看到指令執行的目錄 (/root),還有多個環境變數與實際的指令內容啦!

範例三:由於機房預計於 2015/08/05 停電,我想要在 2015/08/04 23:00 關機?

[root@study ~]# at 23:00 2015-08-04

at> /bin/sync

at> /bin/sync

at> /sbin/shutdown -h now

at>

job 3 at Tue Aug 4 23:00:00 2015

# 您瞧瞧! at 還可以在一個工作內輸入多個指令呢!不錯吧!

事實上,當我們使用 at 時會進入一個 at shell 的環境來讓使用者下達工作指令,此時,建議你最好使用絕對路徑來下達你的指令,比較不會有問題喔!由於指令的下達與 PATH 變數有關,

同時與當時的工作目錄也有關連 (如果有牽涉到檔案的話),因此使用絕對路徑來下達指令,會是比較一勞永逸的方法。

為什麼呢?舉例來說,你在 /tmp 下達『 at now 』然後輸入『 mail -s "test" root < .bashrc 』,

問一下,那個 .bashrc 的檔案會是在哪裡?答案是『 /tmp/.bashrc 』!因為at 在運作時,會跑到當時下達 at 指令的那個工作目錄的緣故啊!

有些朋友會希望『我要在某某時刻,在我的終端機顯示出 Hello 的字樣』,然後就在 at 裡面下達這樣的資訊『

echo "Hello" 』。等到時間到了,卻發現沒有任何訊息在螢幕上顯示,這是啥原因啊?這是因為 at 的執行與終端機環境無關,而所有 standard output/standard error output

都會傳送到執行者的 mailbox 去啦!所以在終端機當然看不到任何資訊。那怎辦?沒關係,

可以透過終端機的裝置來處理!假如你在 tty1 登入,則可以使用『 echo "Hello" > /dev/tty1 』來取代。

Tips

3e5134973d7211edf4b7c756fd7aa12c.gif要注意的是,如果在 at shell 內的指令並沒有任何的訊息輸出,那麼 at 預設不會發 email 給執行者的。

如果你想要讓 at 無論如何都發一封 email 告知你是否執行了指令,那麼可以使用『 at -m 時間格式 』來下達指令喔!

at 就會傳送一個訊息給執行者,而不論該指令執行有無訊息輸出了!

at 有另外一個很棒的優點,那就是『背景執行』的功能了!什麼是背景執行啊?很難瞭解嗎?其實與 bash 的 nohup

(第十六章) 類似啦!

鳥哥提我自己的幾個例子來給您聽聽,您就瞭了!

離線繼續工作的任務:鳥哥初次接觸 Unix 為的是要跑空氣品質模式,

那是一種大型的程式,這個程式在當時的硬體底下跑,一個案例要跑 3 天!由於鳥哥也要進行其他研究工作,因此常常使用 Windows

98 (你沒看錯!鳥哥是老人...) 來連線到 Unix 工作站跑那個 3 天的案例!結果你也該知道, Windows 98 連開三天而不當機的機率是很低的~@_@~

而當機時,所有在 Windows 上的連線都會中斷!包括鳥哥在跑的那個程式也中斷了~嗚嗚~明明再三個鐘頭就跑完的程式,

由於當機害我又得跑 3 天!

另一個常用的時刻則是例如上面的範例三,由於某個突發狀況導致你必須要進行某項工作時,這個 at 就很好用啦!

由於 at 工作排程的使用上,系統會將該項 at 工作獨立出你的 bash 環境中,

直接交給系統的 atd 程式來接管,因此,當你下達了 at 的工作之後就可以立刻離線了,

剩下的工作就完全交給 Linux 管理即可!所以囉,如果有長時間的網路工作時,嘿嘿!

使用 at 可以讓你免除網路斷線後的困擾喔! ^_^

at 工作的管理

那麼萬一我下達了 at 之後,才發現指令輸入錯誤,該如何是好?就將他移除啊!利用 atq 與 atrm 吧!

[root@study ~]# atq

[root@study ~]# atrm (jobnumber)

範例一:查詢目前主機上面有多少的 at 工作排程?

[root@study ~]# atq

3 Tue Aug 4 23:00:00 2015 a root

# 上面說的是:『在 2015/08/04 的 23:00 有一項工作,該項工作指令下達者為

# root』而且,該項工作的工作號碼 (jobnumber) 為 3 號喔!

範例二:將上述的第 3 個工作移除!

[root@study ~]# atrm 3

[root@study ~]# atq

# 沒有任何資訊,表示該工作被移除了!

如此一來,你可以利用 atq 來查詢,利用 atrm 來刪除錯誤的指令,利用 at 來直接下達單一工作排程!很簡單吧!

不過,有個問題需要處理一下。如果你是在一個非常忙碌的系統下運作 at ,

能不能指定你的工作在系統較閒的時候才進行呢?可以的,那就使用 batch 指令吧!

batch:系統有空時才進行背景任務

其實 batch 是利用 at 來進行指令的下達啦!只是加入一些控制參數而已。這個 batch 神奇的地方在於:他會在 CPU 的工作負載小於 0.8 的時候,才進行你所下達的工作任務啦!

那什麼是工作負載 0.8 呢?這個工作負載的意思是: CPU 在單一時間點所負責的工作數量。不是 CPU 的使用率喔!

舉例來說,如果我有一隻程式他需要一直使用 CPU 的運算功能,那麼此時 CPU 的使用率可能到達 100% ,

但是 CPU 的工作負載則是趨近於『 1 』,因為 CPU 僅負責一個工作嘛!如果同時執行這樣的程式兩支呢?

CPU 的使用率還是 100% ,但是工作負載則變成 2 了!瞭解乎?

所以也就是說,當 CPU 的工作負載越大,代表 CPU 必須要在不同的工作之間進行頻繁的工作切換。

這樣的 CPU 運作情況我們在第零章有談過,忘記的話請回去瞧瞧!因為一直切換工作,所以會導致系統忙碌啊!

系統如果很忙碌,還要額外進行 at ,不太合理!所以才有 batch 指令的產生!

在 CentOS 7 底下的 batch 已經不再支援時間參數了,因此 batch 可以拿來作為判斷是否要立刻執行背景程式的依據!

我們底下來實驗一下 batch 好了!為了產生 CPU 較高的工作負載,因此我們用了 12 章裡面計算 pi 的腳本,連續執行 4 次這隻程式,

來模擬高負載,然後來玩一玩 batch 的工作現象:

範例一:請執行 pi 的計算,然後在系統閒置時,執行 updatdb 的任務

[root@study ~]# echo "scale=100000; 4*a(1)" | bc -lq &

[root@study ~]# echo "scale=100000; 4*a(1)" | bc -lq &

[root@study ~]# echo "scale=100000; 4*a(1)" | bc -lq &

[root@study ~]# echo "scale=100000; 4*a(1)" | bc -lq &

# 然後等待個大約數十秒的時間,之後再來確認一下工作負載的情況!

[root@study ~]# uptime

19:56:45 up 2 days, 19:54, 2 users, load average: 3.93, 2.23, 0.96

[root@study ~]# batch

at> /usr/bin/updatedb

at>

job 4 at Thu Jul 30 19:57:00 2015

[root@study ~]# date;atq

Thu Jul 30 19:57:47 CST 2015

4 Thu Jul 30 19:57:00 2015 b root

# 可以看得到,明明時間已經超過了,卻沒有實際執行 at 的任務!

[root@study ~]# jobs

[1] Running echo "scale=100000; 4*a(1)" | bc -lq &

[2] Running echo "scale=100000; 4*a(1)" | bc -lq &

[3]- Running echo "scale=100000; 4*a(1)" | bc -lq &

[4]+ Running echo "scale=100000; 4*a(1)" | bc -lq &

[root@study ~]# kill -9 %1 %2 %3 %4

# 這時先用 jobs 找出背景工作,再使用 kill 刪除掉四個背景工作後,慢慢等待工作負載的下降

[root@study ~]# uptime; atq

20:01:33 up 2 days, 19:59, 2 users, load average: 0.89, 2.29, 1.40

4 Thu Jul 30 19:57:00 2015 b root

[root@study ~]# uptime; atq

20:02:52 up 2 days, 20:01, 2 users, load average: 0.23, 1.75, 1.28

# 在 19:59 時,由於 loading 還是高於 0.8,因此 atq 可以看得到 at job 還是持續再等待當中喔!

# 但是到了 20:01 時, loading 降低到 0.8 以下了,所以 atq 就執行完畢囉!

使用 uptime 可以觀察到 1, 5, 15 分鐘的『平均工作負載』量,因為是平均值,所以當我們如上表刪除掉四個工作後,工作負載不會立即降低,

需要一小段時間讓這個 1 分鐘平均值慢慢回復到接近 0 啊!當小於 0.8 之後的『整分鐘時間』時,atd 就會將 batch 的工作執行掉了!

什麼是『整分鐘時間』呢?不論是 at 還是底下要介紹的 crontab,他們最小的時間單位是『分鐘』,所以,基本上,他們的工作是『每分鐘檢查一次』來處理的!

就是整分 (秒為 0 的時候),這樣瞭解乎?同時,你會發現其實 batch 也是使用 atq/atrm 來管理的!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值