建備份檔案夾:
mkdir mysql_data_bak
建指令碼檔案:
touch autobackupmysql.sh
開啟檔案
vi autobackupmysql.sh
在指令碼中加入如下內容:
filename=`date +%y%m%d`
/usr/bin/mysqldump -uroot -proot boss >/home/mysql_data_bak/$filename.sql
檢查有沒安裝crond,如果沒有,先安裝
yum -y install vixie-cron
yum -y install crontabs
啟動服務 :service crond start
在centos系統中加入開機自動啟動: chkconfig --level 345 crond on
crontab -e
加入內容:00 03 * * * source /root/autobackupmysql.sh 每天凌晨3點執行此檔案,對資料庫進行備份
service crond restart
指令碼內容如下:
#!/bin/sh
# file: /home/mysql/backup.sh
# database info
db_name="test"
db_user="username"
db_pass="password"
# others vars
bin_dir="/usr/local/mysql/bin"
bck_dir="/home/mysql/backup"
date=`date +%f`
# todo
$bin_dir/mysqldump –opt -u$db_user -p$db_pass $db_name | gzip > $bck_dir/db_$date.gz
然後使用將此指令碼加到 /etc/crontab 定時任務中:
01 5 * * 0 mysql /home/mysql/backup.sh
好了,每週日凌晨 5:01 系統就會自動執行 backup.sh 檔案備份 mysql 資料庫了
基本格式 :
* * * * * command
分 時 日 月 周 命令
第1列表示分鐘1~59 每分鐘用*或者 */1表示
第2列表示小時1~23(0表示0點)
第3列表示日期1~31
第4列表示月份1~12
第5列標識號星期0~6(0表示星期天)
第6列要執行的命令
crontab檔案的一些例子:
上面的例子表示每晚的21:30重啟apache。
上面的例子表示每月1、10、22日的4 : 45重啟apache。
上面的例子表示每週
六、週日的1 : 10重啟apache。
上面的例子表示在每天18 : 00至23 : 00之間每隔30分鐘重啟apache。
上面的例子表示每星期六的11 : 00 pm重啟apache。
每一小時重啟apache
晚上11點到早上7點之間,每隔一小時重啟apache
每月的4號與每週一到週三的11點重啟apache
一月一號的4點重啟apache
名稱 : crontab
使用許可權 : 所有使用者
使用方式 :
crontab file [-u user]-用指定的檔案替代目前的crontab。
crontab-[-u user]-用標準輸入替代目前的crontab.
crontab-1[user]-列出使用者目前的crontab.
crontab-e[user]-編輯使用者目前的crontab.
crontab-d[user]-刪除使用者目前的crontab.
crontab-c dir- 指定crontab的目錄。
crontab檔案的格式:m h d m d cmd.
m: 分鐘(0-59)。
h:小時(0-23)。
d:天(1-31)。
m: 月(1-12)。
d: 一星期內的天(0~6,0為星期天)。
cmd要執行的程式,程式被送入sh執行,這個shell只有user,home,shell這三個環境變數
說明 :
crontab 是用來讓使用者在固定時間或固定間隔執行程式之用,換句話說,也就是類似使用者的時程表。-u user 是指設定指定
user 的時程表,這個前提是你必須要有其許可權(比如說是 root)才能夠指定他人的時程表。如果不使用 -u user 的話,就是表示設
定自己的時程表。
引數 :
crontab -e : 執行文字編輯器來設定時程表,內定的文字編輯器是 vi,如果你想用別的文字編輯器,則請先設定 visual 環境變數
來指定使用那個文字編輯器(比如說 setenv visual joe)
crontab -r : 刪除目前的時程表
crontab -l : 列出目前的時程表
crontab file [-u user]-用指定的檔案替代目前的crontab。
時程表的格式如下 :
f1 f2 f3 f4 f5 program
其中 f1 是表示分鐘,f2 表示小時,f3 表示乙個月份中的第幾日,f4 表示月份,f5 表示乙個星期中的第幾天。program 表示要執
行的程式。
當 f1 為 * 時表示每分鐘都要執行 program,f2 為 * 時表示每小時都要執行程式,其餘類推
當 f1 為 a-b 時表示從第 a 分鐘到第 b 分鐘這段時間內要執行,f2 為 a-b 時表示從第 a 到第 b 小時都要執行,其餘類推
當 f1 為 */n 時表示每 n 分鐘個時間間隔執行一次,f2 為 */n 表示每 n 小時個時間間隔執行一次,其餘類推
當 f1 為 a, b, c,... 時表示第 a, b, c,... 分鐘要執行,f2 為 a, b, c,... 時表示第 a, b, c...個小時要執行,其餘類推
使用者也可以將所有的設定先存放在檔案 file 中,用 crontab file 的方式來設定時程表。
例子 :
#每天早上7點執行一次 /bin/ls :
0 7 * * * /bin/ls
在 12 月內, 每天的早上 6 點到 12 點中,每隔3個小時執行一次 /usr/bin/backup :
0 6-12/3 * 12 * /usr/bin/backup
周一到周五每天下午 5:00 寄一封信給 [email protected] :
0 17 * * 1-5 mail -s "hi" [email protected] < /tmp/maildata
每月每天的午夜 0 點 20 分, 2 點 20 分, 4 點 20 分....執行 echo "haha"
20 0-23/2 * * * echo "haha"
注意 :
當程式在你所指定的時間執行後,系統會寄一封信給你,顯示該程式執行的內容,若是你不希望收到這樣的信,請在每一行空一格之
後加上 > /dev/null 2>&1 即可
例子2 :
#每天早上6點10分
10 6 * * * date
#每兩個小時
0 */2 * * * date
#晚上11點到早上8點之間每兩個小時,早上8點
0 23-7/2,8 * * * date
#每個月的4號和每個禮拜的禮拜一到禮拜三的早上11點
0 11 4 * mon-wed date
#1月份日早上4點
0 4 1 jan * date 範例
$crontab -l 列出使用者目前的crontab
Linux配置postgresql自動備份
1 pg dump資料庫備份命令 usr pgsql 9.3 bin pg dump f c o u dotop h 127.0.0.1 p 5432 f data erp data db backup geyt 20170214 09 37 55.sql geyt2.linux配置postgres...
myql自動全備
bin bash 要備份的資料庫名 多個資料庫用空格分開,備份全庫用a databases a 備份檔案要儲存的目錄 basepath data backup if d basepath then mkdir p basepath fi 迴圈databases陣列 for db in do 備份資料...
mairdb自動備份 mariadb自動備份
這裡有一點需要注意,在 mariadb10.3.x 及以上的版本用 percona xtrabackup 工具會有問題。原因可能是 mariadb10.3 以上版本的 redo 日誌格式和之前不同了。percona 的官方文件 mariabackup 的官方文件 percona xtrabackup...