任務計劃
Linux 任務計劃、週期性任務執行:
未來的某時間點執行一次任務:
at
batch :系統自行選擇空閒時間去執行此處指定的任務;
週期性運行某任務:
cron
at 任務
at :Ctrl鍵+d鍵 退出(單行輸入)
at 命令:at [option] TIME
常用選項:
-V 顯示版本信息:
-l: 列出指定隊列中等待運行的作業;相當於atq
-d: 刪除指定的作業;相當於atrm
-c: 查看具體作業任務
-f /path/from/somefile :從指定的文件中讀取任務
-m: 當任務被完成之後,將給用戶發送郵件,即使沒有標準輸出;
注意:作業執行命令的結果中的標準輸出和錯誤以郵件通知給相關用戶;
TIME: 定義出什麼時候進行at 這項任務的時間:
HH:MM [YYYY-mm-dd]
noon, midnight, teatime (4pm),tomorrow
now+#{minutes,hours,days, OR weeks}
at時間格式:
HH:MM 02:00 在今日的HH:MM進行,若該時刻已過,則明天此時執行任務;
HH:MM YYYY-MM-DD 04:00 2016-09-20 規定在某年某月的某一天的特殊時刻進行該項任務
HH:MM[am|pm] [Month] [Date] :
04pm March 17
17:20 tomorrow
HH:MM[am|pm] + number [minutes|hours|days|weeks] 在某個時間點再加幾個時間後才進行該項任務:
now + 5 minutes
04pm + 3 days
執行方式:
1)交互式 2)輸入重定向 3)at –f 文件
依賴與atd 服務, 需要啓動才能實現at任務;
at 隊列存放在/var/spool/at 目錄中;
通過/etc/at.{allow,deny} 控制用戶是否能執行at 任務:
先尋找/etc/at.allow文件(白名單),文件用中的使用者才能使用at ,用沒有在這個文件中的使用者則不能使用 at ( 即使沒有寫在at.deny當中);
如果/etc/at.allow找不存在,就尋找/etc/at.deny(黑名單)這個文件,若寫在這個at.deny的使用者則不能使用at,而沒有在個這個at.deny 文件中的使用者則可使用at命令;
如果某個用戶在這兩個文件中都存在,因白名單的優先級比黑名單高,所以,這個用戶可以使用at這個命令;
如果兩個文件都不存在,只有root可以使用at這個命令;
cron任務
cron:週期性任務計劃;
相關的程序包:
cronie: 主程序包,提供crond 守護進程及相關輔助工具;
cronie-anacron :cronie 的補充程序;用於監控cronie任務執行狀況;如cronie 中的任務在過去該運行的時間點未能正常運行,則anacron會隨後啓動一次此任務;
crontabs :包含CentOS 提供系統維護任務;
確保crond 守護處於運行狀態:
CentOS 7:
systemctl status crond
CentOS 6:
service crond status
計劃週期性執行的任務提交給crond ,到指定時間會自動運行:
系統cron 任務:系統維護作業
/etc/crontab
用戶cron 任務:
crontab 命令
日誌:/var/log/cron
一、系統cron 任務 : /etc/crontab
註釋行以 # 開頭
詳情參見 man 5 crontab
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
例如:晚上9 點10 分運行echo 命令:
10 21 * * * centos /bin/echo "Howdy!"
時間表示法:
(1) 特定值;
給定時間點有效取值範圍內的值;
(2) *
給定時間點上有效取值範圍內的所有值;
表示“每...”
(3) 離散取值:
#,#,#
(4) 連續取值:-
#-#
(5) 在指定時間範圍上,定義步長:
/#: # 即爲步長
例如:每3 小時echo 命令;
0 */3 * * * centos /bin/echo "howdy!"
時間格式:
@reboot Run once after reboot.(每次重啓就執行)
@yearly 0 0 1 1 * (每年1月1號執行)
@annually 0 0 1 1 *(每年1月1號執行)
@monthly 0 0 1 * * (每月1號執行)
@weekly 0 0 * * 0 (每星期日執行)
@daily 0 0 * * * (每天0點0分執行)
@hourly 0 * * * *
系統的計劃任務:
/etc/crontab
/etc/cron.d/ 配置文件
/etc/cron.hourly/ 腳本
/etc/cron.daily/ 腳本
/etc/cron.weekly/ 腳本
/etc/cron.monthly/ 腳本
anacron 系統
運行計算機關機時cron 不運行的任務,CentOS6.0 以後版本取消anacron 服務,由crond 服務管理;
假設計算機沒有一直開機;
對筆記本電腦、臺式機、工作站及其它不一直開機的系統很重要;
對偶爾要關機的服務器很有用;
配置文件:/etc/anacrontab ,負責執行/etc/cron.daily /etc/cron.weekly /etc/cron.monthly 中系統任務。/etc/cron.hourly/ 由/cron.d/0hourly 執行:
字段1 :如果在這些日子裏沒有運行這些任務……
字段2 :在重新引導後等待這麼多分鐘後運行它
字段3 :任務識別器,在日誌文件中標識
字段4 :要執行的任務
管理臨時文件:
rhel6.0 使用/etc/cron.daily/tmpwatch 定時清除臨時文件。
rhel7.0 使用systemd-tmpfiles-setup 服務實現
配置文件:
/etc/tmpfiles.d/*.conf
/run/tmpfiles.d/*.conf
/usr/lib/tmpfiles/*.conf
/usr/lib/tmpfiles.d/tmp.conf:
d /tmp 1777 root root 10d
d /var/tmp 1777 root root 30d
命令:
systemd-tmpfiles –clean|remove|create configfile
當執行任務時,更新/var/spool/anacron/ 文件時間戳;
二、用戶cron
run-parts 運行這個文件中的所有任務;
crontab 命令定義,每個用戶都有專用的cron 任務文件:/var/spool/cron/USERNAME
crontab 命令:
crontab [-u user] [-l | -r | -e] [-i]
-l: 列出所有任務;
-e: 編輯任務;
-r: 移除所有任務;
-i :同-r 一同使用,以交互式模式移除指定任務
-u user: 僅root 可運行,指定用戶管理cron 任務
控制用戶執行計劃任務 :
/etc/cron.{allow,deny}
1,如果將用戶加入黑名單:
即使你將某個用戶加入黑名單,但是這個用戶已經創建的任務還會繼續執行,但不能繼續創建任務;
2,如果將用戶即加入黑名單也加入白名單:
將某個用戶即加入黑名單也加入白名單,則這個用戶不僅可以繼續執行以前的任務,而且也可以創建新的任務;
3,如果黑名單和白名單都是空的,那麼只有root用戶可以創建任務:
注意:運行結果的標準輸出和錯誤以郵件通知給相關用戶
(1) COMMAND > /dev/null
(2) COMMAND &> /dev/null
對於cron 任務來講,% 有特殊用途;如果在命令中要使用%,則需要轉義;不過,如果把%放置於單引號中,也可以不用轉義;
at 和crontab:
用 一次性作業使用 at
重複性作業使用crontab
Create at time crontab -e
List at -l crontab -l
Details at -c jobnum N/A
Remove at -d jobnum crontab -r
Edit N/A crontab -e
沒有被重定向的輸出會被郵寄給用戶;
根用戶能夠修改其它用戶的作業;