linux計畫任務通過執行指令碼備份xampp安裝的mysql資料庫
鄧強 1. 首先編輯計畫任務
# vim /etc/crontab 加入以下**:
# mysqldump mysqlbases to this file
0 2 * * * root /usr/bin/mysqlbak
這是設定每天2點定時執行
mysqlbak檔案,mysqlbak是乙個指令碼檔案,下面會寫到其中內容。
2. 建立mysql資料庫備份到的資料夾並給予此資料夾寫入的許可權
# mkdir /home/mysqldatabak
# chmod -r 777 /home/mysqldatabak
3. 建立shell指令碼檔案mysqlbak
# vi /usr/bin/mysqlbak
#!/bin/sh
# mysql_backup.sh: backup mysql databases and keep newest 5 days backup.
## your mysql login information
# db_user is mysql username
# db_passwd is mysql password
# db_host is mysql host
# -----------------------------
db_user="root"
db_passwd="123456"
db_host="localhost"
# the directory for story your backup file.
backup_dir="/home/mysqldatabak"
# date format for backup file (dd-mm-yyyy)
time="$(date +"%y-%m-%d")"
# mysql, mysqldump and some other bin's path
mysql="/opt/lampp/bin/mysql"
# "$(which mysql)"
mysqldump="/opt/lampp/bin/mysqldump"
#"$(which mysqldump)"
mkdir="$(which mkdir)"
rm="$(which rm)"
mv="$(which mv)"
gzip="$(which gzip)"
# check the directory for store backup is writeable
test ! -w $backup_dir && echo "error: $backup_dir is un-writeable." && exit 0
# the directory for story the newest backup
test ! -d "$backup_dir/backup.0/" && $mkdir "$backup_dir/backup.0/"
# get all databases
all_db="$($mysql -u$db_user -h$db_host -p$db_passwd -bse 'show databases')"
for db in $all_db
do$mysqldump -u $db_user -h $db_host -p$db_passwd $db | $gzip -9 > "$backup_dir/backup.0/$time.$db.gz"
done
# delete the oldest backup
test -d "$backup_dir/backup.5/" && $rm -rf "$backup_dir/backup.5"
# rotate backup directory
for int in 4 3 2 1 0
doif(test -d "$backup_dir"/backup."$int")
then
next_int=`expr $int + 1`
$mv "$backup_dir"/backup."$int" "$backup_dir"/backup."$next_int"
fidone
exit 0;
4.
給/usr/bin/mysqlbak指令碼可執行的許可權
# chmod +x /usr/bin/mysqlbak
最後重啟計畫任務 service crond restart
5. 這樣在 /home/mysqldatabak/ 每天的凌晨2時會自動執行此指令碼,然後備份資料庫到此目錄。如下圖所示則說明備份成功:
<1>
<2>
本文修改自:
linux中計畫任務執行指令碼
我使用的是ubuntu14.4,所以在ubuntu中一切正常,在其他linux系統中應該都差不多。1 計畫任務,crontab命令選項 u指定乙個使用者,l列出某個使用者的任務計畫,r刪除某個使用者的任務,e編輯某個使用者的任務 2 cron檔案語法 分 小時 日 月 星期 命令 0 59 0 23...
MySQL定時執行指令碼 計畫任務 例項
具體 在mysql中我們可以直接進行一些引數設定讓它成定時為我們執行一些任務了,這個雖然可以使用windows或者linux中的計畫任務實現,但是mysql本身也能完成。檢視event是否開啟 如下 複製 show variables like sche 將事件計畫開啟 如下 複製 set glob...
MySQL定時執行指令碼 計畫任務 命令例項
檢視event是否開啟 複製 如下 show variables like sche 將事件計畫開啟 複製 如下 set global event scheduler 1 建立儲存過程test 複製 如下 create procedure test begin update examinfo set...