linux crontab定時任務運行shell指令碼(shell執行sql檔案)

來源:互聯網
上載者:User

標籤:echo   內容   fan   資料   mvp   alq   ++   dts   pki   

今天做個linux定時任務(每晚12點把表匯總)。

順便寫個部落格記錄一下~~

為什麼用linux定時任務,而不是在項目加定時任務呢?原因就是防止因為各種原因項目崩潰。。所以就用了更加穩定的linux定時任務(我是這麼想的( ^_^ ))。

起初我感覺很簡單,以為頂多半小時就搞定了,,,結果從10點弄到12點半才搞定(主要是我英語太渣和資料庫報錯導致)。。。

︿( ̄︶ ̄)︿廢話到此結束---------------

crontab 格式     *  *  *  *  *      XXX

         分    時     天    月    星期   命令

符號      “*”代表取值範圍內的數字,
              “/”代表”每”,
              “-”代表從某個數字到某個數字,
              “,”分開幾個離散的數字 

例子

    30    3    10,20   *    *     ls     每月10號及20號的3:30執行ls命令[註:“,”用來串連多個不連續的時段]

       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命令[即每月的1、11、21、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"這個參數了,如果去掉這個參數的話,後面就可以寫要啟動並執行某個指令碼名,而不是檔案夾名了。

 

************************************************************************************

 

 

linux crontab定時任務運行shell指令碼(shell執行sql檔案)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.