開筆
最近在做數據收集涉及到一些日志文件輪轉切割,筆者想用一個定時任務來實現定時輪轉。調研后決定使用 Linux 系統的 cron 服務。
Cron 是Uninx系(Linux) 操作系統的后臺駐留程序,系統管理員用得相對多一些。Cron 可以被設置為開機啟動,在 centos 中默認就是開機啟動的服務。
在使用 cron 服務的時候,往往我們都需要 先確認cron服務本身是否開啟,處于運行狀態,確認當前用戶是否有權限正常使用cron,編輯下發cron計劃任務,確認我們的計劃任務是否如約按照計劃執行。本篇筆者就和大家一起看看:
- 查看當前系統cron服務狀態
- 管理 cron 服務
- 配置 corn 服務權限
- 編輯下發 cron 計劃任務
- 查看 任務是否按照計劃執行
cron服務查看
除了可以用 ps 命令查看 cron 服務進程運行狀態,還可以查看正在運行的cron服務調度本身的狀態。通過 crontab 命令對cron服務的設置。用:
man crontab
查看一下crontab命令,發現,crontab 有4個可選參數:
- -u:設定某個用戶的cron服務,一般root用戶在執行這個命令的時候需要此參數
- -l:列出某個用戶cron服務的詳細內容
- -r:刪除某個用戶的cron服務
- -e:編輯某個用戶的cron服務
cron服務管理
如果經過查看,我們發現cron并不是你要的狀態,那么就開始管理它吧。作為后臺服務,cron有著與我們熟知的服務程序相似地基本管理命令:啟動、停止、重啟、重新載入配置(需要稍微注意一點,這里是crond 而不是 cron):
-
啟動服務:
/sbin/service crond star
-
關閉服務
/sbin/service crond stop
-
重啟服務
/sbin/service crond restart
-
重新載入配置
在每一次重新修改過cron配置文件,請務必重新載入一下配置:
/sbin/service crond reload
配置 corn 服務權限
在 Linux 操作系統中,對用戶使用cron服務的權限控制在 /etc/cron.allow 和 /etc/cron.deny 兩個文件中配置實現,但 /etc/cron.allow 文件非必須存在的。
如果 /etc/cron.allow 文件存在,則所有需要運行 crontab 命令的用戶必須在這個文件被列舉出來;如果 /etc/cron.allow 文件不存在,但
/etc/cron.deny 文件存在,則所有需要運行 crontab 命令的用戶必須在這個文件不被列舉出來。當這兩個文件都不存在的情況下,在一些 Linux 系統(如 Ubuntu、Debian ,但不是所有)允許所有用戶運行 crontab 命令。
需要注意的是,系統中,不在 /etc/shadow 文件所列的用戶,是沒有權限使用 crontab 命令。
編輯cron任務
-
語法
* * * * * Command_to_execute - – – – - | | | | | | | | | +—– Day of week (0–6) (Sunday=0) or Sun, Mon, Tue,… | | | +———- Month (1–12) or Jan, Feb,… | | +————-— Day of month (1–31) | +——————– Hour (0–23) +————————- Minute (0–59)
-
示例
每天凌晨輪轉nginx的access日志
01 00 * * * /usr/sbin/logrotate /etc/logrotate.d/nginx-access-log.conf
系統便會在每天凌晨壹分的時刻執行
/usr/sbin/logrotate /etc/logrotate.d/nginx-access-log.conf
命令,實際就是每天凌晨進行日志輪轉