linux crontab定時任務運行shell腳本(shell執行sql文件)

今天作個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"這個參數了,若是去掉這個參數的話,後面就能夠寫要運行的某個腳本名,而不是文件夾名了。

 

************************************************************************************
相關文章
相關標籤/搜索