Linux計畫任務通過執行指令碼

2021-07-09 03:17:21 字數 2365 閱讀 6614

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...