高見龍

iOS app/Ruby/Rails Developer & Instructor, 喜愛非主流的新玩具 :)

Crontab & At

在Linux系統,crontabat都是可以用來做排程,但這兩者的差異是:

at:工作僅執行一次後就會系統中的排程中取消,工作排程會寫入到/var/spool/at目錄下。 crontab:工作將持續例行性的執行,工作排程會寫入 /var/spool/cron。

at的使用方法:

> at TIME

如果使用-m參數,則 at會把排程輸出的結果 mail 給下達指令的使用者。

> at 5am
warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh

at> mail eddie -s “hi, eddie”

按下Ctrl+D就可離開at環境

job 1 at 2005-01-19 05:00

使用atq可看目前的at排程

> atq
1 2005-01-19 05:00 a root

其中第一個1代表這個排程的編號

使用atm指令可移除已排好的工作

> atm 1

接下來介紹crontab的用法:

> crontab [-u user] [-l | -e | -r]
-u user :只有 root可使用,可以編譯其他使用者的crontab內容。
-l:列出 crontab 內容。
-e:編輯 crontab 內容。
-r:刪除 crontab 內容。

執行crontab -e之後,則會進入一般的文字編輯器畫面編輯。

時間部份有5個欄位,分別是「分」、「時」、「日」、「月」、「星期幾」,最後就是要執行的工作,例如:

0 12 * * * mail eddie -s test

就是在每個月的每天的12點0分時,寄一封主旨為test的mail給eddie。其中,「*」代表所有數字。星期幾這欄數值由0~6,0代表星期日。再看一個例子:

*/5 * * * * mail eddie -s test

其中「*/5」表示每5分鐘寄一次信。

另外要注意的是,如果只是要刪除某個 crontab 的工作項目,建議使 crontab -e 來編輯,因為使用-r參數,會將所有的工作都移除。

如果是系統的例行性工作,不需要以某人的權限執行,則可編輯「/etc/crontab」檔案,詳細的內容在/etc/crontab檔案裡面有說明。

安裝phpMyAdmin遇到的問題

MySQL 4.1 以上版本為了提高安全性,使用了新的密碼驗證機制。 所以,MySQL 的 Client Library 需要 4.0 版本以上。 但目前在 Client 端所使用的 PHP 版本若為 5.0 以下(如 4.3.9) 內建的 MySQL Library 大都為 3.23,並不支援新版的密碼驗證機制。

解決方案

一、將 PHP 升級為 5.0版以上:

但是大部份的伺服器,包括諸多 Blog 平台,尚未支援 PHP5,這點倒是挺麻煩。

二、MySQL console 下,更新密碼形式改為 OLD_PASSWORD() (設回原來舊版的密碼驗證機制)。

mysql> UPDATE mysql.user SET Password = OLD_PASSWORD(’新的密碼’) WHERE Host = ‘localhost’ AND User = ‘root’
mysql> FLUSH PRIVILEGES;

參考文件

  • MySQL Manual - A.2.3 Client does not support authentication protocol