Linux下,有兩個命令可以用來作為計劃任務而執(zhí)行,
創(chuàng)新互聯(lián)建站長期為1000+客戶提供的網站建設服務,團隊從業(yè)經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網生態(tài)環(huán)境。為晉江企業(yè)提供專業(yè)的做網站、成都網站建設,晉江網站改版等技術服務。擁有10余年豐富建站經驗和眾多成功案例,為您定制開發(fā)。
要使用一次性任務計劃,linux必須要有負責這個計劃任務的服務,那就是atd服務
但是并非所有的linux distribution都默認會打開,我們需要手動激活愛聽的任務
如果服務未安裝,則需要手動安裝
#:yum install - y at 或 #:apt-get install at
如果擔心啟動是否執(zhí)行OK的話,可使用命令查看:
#:ps aux |grep atd
或者使用
systemctl status atd
# 查閱一下 atd 目前的狀態(tài),Active 狀態(tài)應是 running
使用 at 這個指令來產生所要運行的工作,并 將這個工作以文本文件的方式寫入 /var/spool/cron/atjobs/ 目錄內,該工作便能等待 atd 這個服務的取用與執(zhí)行了。 不過,因為安全的理由,并不是所有的人都可以進行 at 工作調度!
at 的使用限制是利用 /etc/at.allow 與 /etc/at.deny 這兩個文件來進行的! 加上這兩個文件后,at 的工作情況其實是這樣的:
在一般的 distributions 當中,由于假設系統(tǒng)上的所有用戶都是可信任的,因此系統(tǒng)通常會保留一個空的 /etc/at.deny 文件,意思是允 許所有人使用 at 指令的意思 (您可以自行檢查一下該文件)。 不過,萬一你不希望有某些 使用者使用 at 的話,將那個使用者的帳號寫入 /etc/at.deny 即可! 一個帳號寫一行。
單一工作調度的進行就使用 at 這個指令!這個指令的運行非常簡單!將 at 加上一個時間即可!基本的語法如下:
事實上,當我們使用 at 時會進入一個 at shell 的環(huán)境來讓使用者下達工作指令,此時,建議 你最好使用絕對路徑來下達你的指令,比較不會有問題!由于指令的下達與 PATH 變量有關, 同時與當時的工作目錄也有關連 (如果有牽涉到文件的話),因此使用絕對路徑來下達 指令,會是比較一勞永逸的方法。 舉例來說,你在 /tmp 下達 at now 然后輸入 mail -s "test" root .bashrc , 問一下,那個 .bashrc 的文件會是在哪里?答案是 /tmp/.bashrc !因為 at 在運行時,會跑到當時下達 at 指令的那個工作目錄運行!
要注意的是,如果在 at shell 內的指令并沒有任何的訊息輸出,那么 at 默認不會發(fā) email 給執(zhí)行者的。 如果你想要讓 at 無論如何都發(fā)一封 email 告知你是否執(zhí)行了指令,那么 可以使用“ at -m 時間格式 ”來下達指令! at 就會傳送一個訊息給執(zhí)行者,而不論該指令執(zhí)行有無訊息輸出了!
如果要在某某時刻,在我的終端機顯示出 Hello 的字樣,可以通過終端機的設備來處理!假如你在 tty1 登陸(在命令行里面輸入 tty 可以查看),則可以使用 echo "Hello" /dev/tty1 。
at 有另外一個很棒的優(yōu)點, 由于 at 工作調度的使用上,系統(tǒng)會將該項 at 工作獨立出你的 bash 環(huán)境中, 直接交給系統(tǒng)的 atd 程序來接管,因此,當你下達了 at 的工作之后就可以立刻離線了, 剩下的工作就完全交 給 Linux 管理即可!所以如果有長時間的網絡工作時,使用 at 可以讓你免除網絡斷線后的困擾。
其實 batch 是利用 at 來進行指令的下達!只是加入一些控制參數而已。這個 batch 神奇的地方在于:他會在 CPU 的工作負載小于 0.8 的時候,才進行你所下達的工作任務啦!
那什么是工作負載 0.8 呢?這個工作負載的意思是: CPU 在單一時間點所負責的工作數量。不是CPU 的使用率喔! 舉例來說,如果我有一只程序他需要一直使用 CPU 的運算功能,那么此 時 CPU 的使用率可能到達 100% , 但是 CPU 的工作負載則是趨近于“ 1 ”,因為 CPU 僅負責一個工作!如果同時執(zhí)行這樣的程序兩支呢? CPU 的使用率還是 100% ,但是工作負載 則變成 2 了! 所以也就是說,當 CPU 的工作負載越大,代表 CPU 必須要在不同的工作之間進行頻繁的工 作切換。 因為一直切換 工作,所以會導致系統(tǒng)忙碌??! 系統(tǒng)如果很忙碌,還要額外進行 at ,不太合理!所以才有 batch 指令的產生!
下面來實驗一下 batch 好了!為了產生 CPU 較高的工作負載,我們用了 計算 pi 的腳本,連續(xù)執(zhí)行 4 次這只程序, 來仿真高負載,然后看看batch 的工作現象。
使用 uptime 可以觀察到 1, 5, 15 分鐘的“平均工作負載”量,因為是平均值,所以當我們如上 表刪除掉四個工作后,工作負載不會立即降低, 需要一小段時間讓這個 1 分鐘平均值慢慢回 復到接近 0 ??!當小于 0.8 之后的“整分鐘時間”時,atd 就會將 batch 的工作執(zhí)行掉了!
什么是“整分鐘時間”呢?不論是 at 還是 crontab,他們最小的時間單位是“分 鐘”,所以,基本上,他們的工作是“每分鐘檢查一次”來處理的! 就是整分 (秒為 0 的時候),同時,你會發(fā)現其實 batch 也是使用 atq/atrm 來管理的!
與crond不同的是,at任務調度是一次性的,而crond是重復性的
1.1 at命令是一次性定時計劃任務,at的守護進程atd會以后臺模式運行,檢查作業(yè)隊列來運行
1.2 默認情況下,atd守護進程每60s檢查作業(yè)隊列,有作業(yè)時,會檢查作業(yè)運行時間,如果時間與當前時間匹配,則運行此作業(yè)
1.3 at命令是一次性定時計劃任務,執(zhí)行完一個任務后就不再執(zhí)行這個任務了
1.4 在使用at命令的時候,一定要保證atd進程的啟動,可以使用相關指令查看
ps -ef | grep atd 可以檢查atd是否在運行
at [選項] [時間]
按兩次 ctrl+d 結束at命令的輸入
4.1 當天的hh:mm(小時:分鐘),假如這個時間已經過去,那么就第二天的這個時間執(zhí)行。例如04:00
4.2 模糊的詞語,例如midnight、noon、teatime(下午茶時間,16:00左右)
4.3 采用12小時計時制,例如8am
4.4 指定執(zhí)行命令的具體日期,格式為month dat(月 日)或者mm/dd/yy或者dd.mm.yy,指定的日期必須跟著寫在在指定時間的后面,例如:04:00 2021-3-1就是2021年3月1日凌晨4點整執(zhí)行
4.5 相對計時法,指定格式為now + count time-units,now就是當前時間,time-units是時間單位,可以是minutes、hours、days、weeks。count是時間的數量,例如:now + 5 minutes
4.6 直接用today、tomorrow來指定完成命令的時間
5.1 2天后的下午5點,執(zhí)行/bin/ls /home指令
at 5pm + 2 days 按回車鍵
然后寫下那個時刻要執(zhí)行命令 /bin/ls /home
最后按兩次ctrl+d退出at指令
5.2 atq指令可以直接執(zhí)行,查看系統(tǒng)中待執(zhí)行的工作任務
5.3 明天17:00輸出時間到指定文件內 /root/date100.log
at 17:00 tomorrow 按回車鍵
date /root/date100.log
按兩次ctrl+d退出at指令的輸入
5.4 2分鐘后
at now + 2 minutes
5.5 刪除已經設置的任務,atrm 編號
可以用atq列出待執(zhí)行的任務,列出后第一列就是job編號
一般linux系統(tǒng)中定時周期性任務的執(zhí)行我們都是用crontab去實現,而執(zhí)行延時任務的話比較少人會用到atd服務。之前項目中有需要用到執(zhí)行延時任務的場景,因為偷懶,懶得自己寫工具去實現,就使用了atd服務的at命令創(chuàng)建一個延時任務,結果延時任務竟然沒執(zhí)行。剛好團隊內部要分享,覺得這個問題還是有一定價值,先記錄下吧。
(注:atd服務centos7中minimal版是沒有自帶的,需要yum進行安裝,安裝完畢可以執(zhí)行at命令進行任務下發(fā),兩種方式:1、echo "command" | at now + 時間間隔的形式;2、at命令交互shell的方式)
出現問題的時候查看/var/log/messages等系統(tǒng)日志并沒看出什么有效信息,網絡上也幾乎沒找到相關的信息。最終,在嘗試復現時,發(fā)現了問題所在,linux系統(tǒng)提示“You have mail in /var/spool/mail/root”,tail -f一查看就基本明確了,下面是通過在/root/attest目錄下創(chuàng)建echo "echo 10 /root/task.txt | at now + 2 minute"任務后,刪除attest目錄后復現出的現象,日志中提示如下:
郵件提示是運行時的路徑找不到了,原來是通過at下發(fā)的任務在運行時還依賴執(zhí)行下發(fā)動作時的工作目錄,如果你在下發(fā)完任務后,把當時的路徑給刪掉了,那這個任務就GG了。其實可以在下發(fā)完任務后通過atq獲取到任務編號,并通過at -c 加任務編號查看任務信息,任務信息中有記錄運行任務所需的工作路徑。
請忽略上圖中任務id不一致的情況,上圖僅僅是為了說明問題。
atd是linux 下一次性定時計劃任務命令的守候進程。
查看
ps -ef | grep atd
配置開機啟動
/etc/init.d/atd start or restart