使用shell腳本自動備份MySQL數(shù)據(jù)庫的具體操作

不知道大家之前對類似使用shell腳本自動備份MySQL數(shù)據(jù)庫的具體操作的文章有無了解,今天我在這里給大家再簡單的講講。感興趣的話就一起來看看正文部分吧,相信看完使用shell腳本自動備份MySQL數(shù)據(jù)庫的具體操作你一定會有所收獲的。

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了松滋免費建站歡迎大家使用!

目的:

192.168.1.2服務(wù)器對192.168.1.1服務(wù)器上的MySQL數(shù)據(jù)庫進行備份。

必須滿足的條件:

1、在192.168.1.1服務(wù)器上創(chuàng)建專門用來備份的數(shù)據(jù)庫賬號,并賦予相應(yīng)的權(quán)限:

mysql> grant select,lock tables on *.* to 'operator'@'192.168.%.%' identified by '123456';   
#備份數(shù)據(jù)庫需要賬號具有查看表和鎖定表的權(quán)限

2、在192.168.1.2服務(wù)器上使用該賬號進行手工備份,測試是否可以備份成功:

[root@localhost ~]# mysqldump -u operator -p123456 -h 192.168.1.1 --databases test1 > test1.sql

編寫shell腳本:

[root@localhost ~]# mkdir -p /opt/backup             #創(chuàng)建備份后的存放目錄
[root@localhost ~]# vim mysqlbak.sh                  #編寫shell腳本

#!/bin/bash
#定義數(shù)據(jù)庫連接、目標(biāo)信息庫等信息:
user="operator"       #定義用戶名賬號
pass="123456"        #密碼
host="192.168.1.1"          #目標(biāo)主機
conn=" -u $user -p$pass -h $host"
data1="test1"             #備份目標(biāo)庫
data2="test2"              
bak="/opt/backup"         #指定備份目錄
cmd="/usr/local/mysql/bin/mysqldump"       #指定命令工具
time=`date +%Y%m%d-%H%M`             #定義時間變量
name_1="$data1-$time"                  #定義備份后的名字
name_2="$data2-$time"
cd $bak       #切換至備份目錄下
$cmd $conn --databases $data1 > $name_1.sql            #備份為.sql文件
$cmd $conn --databases $data2 > $name_2.sql
/bin/tar zcf $name_1.tar.gz $name_1.sql --remove > /dev/null             #打包后刪除源文件
/bin/tar zcf $name_2.tar.gz $name_2.sql --remove > /dev/null

測試備份是否成功:

[root@localhost ~]# chmod +x mysqlbak.sh            #賦予該腳本執(zhí)行權(quán)限
[root@localhost ~]# ./mysqlbak.sh             #執(zhí)行腳本測試是否備份成功
Warning: Using a password on the command line interface can be insecure.
Warning: Using a password on the command line interface can be insecure.
[root@localhost ~]# ls /opt/backup/                   #查看備份后的文件,OK!
test1-20190521-2254.tar.gz  test2-20190521-2254.tar.gz

設(shè)置計劃任務(wù):

[root@localhost ~]# mv mysqlbak.sh /opt/backup/              #將腳本也移至備份目錄
[root@localhost backup]# crontab -e          #編輯計劃任務(wù)
00      22      *       *       *       /opt/backup/mysqlbak.sh

[root@localhost backup]# systemctl status crond             #確保crond服務(wù)已運行
● crond.service - Command Scheduler
   Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)
   Active: active (running) since 二 2019-05-21 22:15:30 CST; 49min ago
 Main PID: 1493 (crond)
    Tasks: 1
   CGroup: /system.slice/crond.service
           └─1493 /usr/sbin/crond -n

看完使用shell腳本自動備份MySQL數(shù)據(jù)庫的具體操作這篇文章,大家覺得怎么樣?如果想要了解更多相關(guān),可以繼續(xù)關(guān)注我們的行業(yè)資訊板塊。

當(dāng)前名稱:使用shell腳本自動備份MySQL數(shù)據(jù)庫的具體操作
網(wǎng)頁鏈接:http://bm7419.com/article28/isgpcp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計公司、外貿(mào)網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、靜態(tài)網(wǎng)站商城網(wǎng)站網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管