天天看點

linux定時指令日志檔案

    最近發覺一個比較頭痛的問題,或許是由于開發人員的疏忽客戶幾次反應伺服器,能通路但不能使用,于是進入背景查了下,習慣性的df / -h發現磁盤已寫滿;于是找到了日志檔案的所在目錄ll -h  發覺錯誤的日志檔案每個檔案大小有1G多

    用tail 指令檢視了下錯誤資訊發覺是資料庫問題報錯,錯誤資訊如下:

java.sql.SQLException: Syntax error or access violation,  message from server: "You have an error in your SQL syntax.  Check the manual that corresponds to your MySQL server version for the right syntax to use near '台北小棧'休閑吧12月15号開業了.

   曾傻傻認為是資料錄入這條資料而導緻機器報錯,于是把整個資料庫down下來查找這條資料,未果;于是想到linux的定時指令,讓機器定時删除報錯檔案,這也是解決問題的一種辦法雖然有點笨

參照綠色字型的說法,網頁引用不過來,隻能貼過來了;

說法,我使用的第二種方法

1.在/etc/下建立了一個cron.test檔案寫入删除日志檔案指令如下:

     rm -rf /usr/local/im/WEB-INF/log/*log_2008-0*

2.儲存檔案後,chmod  777 cron.test;

3.在/etc/crontab檔案中加下一條語句如下:

     42 4 1 * * root  ./etc/cron.test

4./sbin/service crond restart //重新開機服務

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/2,8 * * * 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"這個參數了,如果去掉這個參數的話,後面就可以寫要運作的某個腳本名,而不是檔案夾名了。

繼續閱讀