今天作個linux定時任務(每晚12點把表彙總)。linux
順便寫個博客記錄一下~~sql
爲何用linux定時任務,而不是在項目加定時任務呢?緣由就是防止由於各類緣由項目崩潰。。因此就用了更加穩定的linux定時任務(我是這麼想的( ^_^ ))。shell
起初我感受很簡單,覺得頂多半小時就搞定了,,,結果從10點弄到12點半才搞定(主要是我英語太渣和數據庫報錯致使)。。。數據庫
︿( ̄︶ ̄)︿廢話到此結束---------------bash
crontab 格式 * * * * * XXX編輯器
分 時 天 月 星期 命令工具
符號 「*」表明取值範圍內的數字,
「/」表明」每」,
「-」表明從某個數字到某個數字,
「,」分開幾個離散的數字 url
例子spa
30 3 10,20 * * ls 每個月10號及20號的3:30執行ls命令[注:「,」用來鏈接多個不連續的時段]rest
25 8-11 * * * ls 天天8-11點的第25分鐘執行ls命令[注:「-」用來鏈接連續的時段]
*/15 * * * * ls 每15分鐘執行一次ls命令 [即每一個小時的第0 15 30 45 60分鐘執行ls命令 ]
30 6 */10 * * ls 每月中,每隔10天6:30執行一次ls命令[即每個月的一、十一、2一、31日是的6:30執行一次ls 命令。 ]
如今來介紹個人具體操做步驟(包括編寫shell腳本 並執行編寫的sql文件)
打開linux終端>進入cat(我本身建立的)目錄>建立crontab文件夾 並進入> 執行命令 crontab -e進入編輯狀態編寫crontab表達式 1 * * * * /cat/crontab/sbin.sh(天天凌晨1點執行total.sh腳本)>
Ctrl+X 建退出>Yes(保存)>回車> crontab -l (若是能看到你剛纔保存的crontab,就成功了~~)
(。。。浪費時間的緣由是個人保存退出和博客上那些寫的不同。。)往下看☟☟☟☟
例子:
假設當前用戶是root,要創建root用戶的定時任務
crontab -e
選擇編輯器,編輯定時任務(這裏假設是編輯器是vi)
按i進入編輯模式
1 * * * * /cat/crontab/sbin.sh
按esc退出編輯模式進入普通模式,輸入:x或:wq保存退出
上幾張圖~~
簡單的執行sql的shell腳本
注意事項
新建立的cron job,不會立刻執行,至少要過2分鐘才執行。若是重啓cron則立刻執行。
下面再附一篇介紹:
************************************************************************************
cron是一個linux下的定時執行工具,能夠在無需人工干預的狀況下運行做業。因爲Cron 是Linux的內置服務,但它不自動起來,能夠用如下的方法啓動、關閉這個服務:
/sbin/service crond start //啓動服務
/sbin/service crond stop //關閉服務
/sbin/service crond restart //重啓服務
/sbin/service crond reload //從新載入配置
你也能夠將這個服務在系統啓動的時候自動啓動:
在/etc/rc.d/rc.local這個腳本的末尾加上:
/sbin/service crond start
如今Cron這個服務已經在進程裏面了,咱們就能夠用這個服務了,Cron服務提供如下幾種接口供你們使用:
1.直接用crontab命令編輯
cron服務提供crontab命令來設定cron服務的,如下是這個命令的一些參數與說明:
crontab -u //設定某個用戶的cron服務,通常root用戶在執行這個命令的時候須要此參數
crontab -l //列出某個用戶cron服務的詳細內容
crontab -r //刪除沒個用戶的cron服務
crontab -e //編輯某個用戶的cron服務
好比說root查看本身的cron設置:crontab -u root -l
再例如,root想刪除fred的cron設置:crontab -u fred -r
在編輯cron服務時,編輯的內容有一些格式和約定,輸入:crontab -u root -e
進入vi編輯模式,編輯的內容必定要符合下面的格式:*/1 * * * * ls >> /tmp/ls.txt
這個格式的前一部分是對時間的設定,後面一部分是要執行的命令,若是要執行的命令太多,能夠把這些命令寫到一個腳本里面,而後在這裏直接調用這個腳本就能夠了,調用的時候記得寫出命令的完整路徑。時間的設定咱們有必定的約定,前面五個*號表明五個數字,數字的取值範圍和含義以下:
分鐘 (0-59)
小時(0-23)
日期(1-31)
月份(1-12)
星期(0-6) //0表明星期天
除了數字還有幾個個特殊的符號就是"*"、"/"和"-"、",",*表明全部的取值範圍內的數字,"/"表明每的意思,"*/5"表示每5個單位,"-"表明從某個數字到某個數字,","分開幾個離散的數字。如下舉幾個例子說明問題:
天天早上6點
-----------------
0 6 * * * echo "Good morning." >> /tmp/test.txt //注意單純echo,從屏幕上看不到任何輸出,由於cron把任何輸出都email到root的信箱了。
每兩個小時
-----------------
0 */2 * * * echo "Have a break now." >> /tmp/test.txt
晚上11點到早上8點之間每兩個小時,早上八點
-----------------
0 23-7/28 * * * echo "Have a good dream:)" >> /tmp/test.txt
每月的4號和每一個禮拜的禮拜一到禮拜三的早上11點
-----------------
0 11 4 * 1-3 command line
1月1日早上4點
-----------------
0 4 1 1 * command line
每次編輯完某個用戶的cron設置後,cron自動在/var/spool/cron下生成一個與此用戶同名的文件,此用戶的cron信息都記錄在這個文件中,這個文件是不能夠直接編輯的,只能夠用crontab -e 來編輯。cron啓動後每過一份鍾讀一次這個文件,檢查是否要執行裏面的命令。所以此文件修改後不須要從新啓動cron服務。
2.編輯/etc/crontab 文件配置cron
cron服務每分鐘不只要讀一次/var/spool/cron內的全部文件,還須要讀一次/etc/crontab,所以咱們配置這個文件也能運用cron服務作一些事情。用crontab配置是針對某個用戶的,而編輯/etc/crontab是針對系統的任務。此文件的文件格式是:
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root //若是出現錯誤,或者有數據輸出,數據做爲郵件發給這個賬號
HOME=/ //使用者運行的路徑,這裏是根目錄
# run-parts
01 * * * * root run-parts /etc/cron.hourly //每小時執行/etc/cron.hourly內的腳本
02 4 * * * root run-parts /etc/cron.daily //天天執行/etc/cron.daily內的腳本
22 4 * * 0 root run-parts /etc/cron.weekly //每星期執行/etc/cron.weekly內的腳本
42 4 1 * * root run-parts /etc/cron.monthly //每個月去執行/etc/cron.monthly內的腳本
你們注意"run-parts"這個參數了,若是去掉這個參數的話,後面就能夠寫要運行的某個腳本名,而不是文件夾名了。
************************************************************************************