使用shell腳本實現自動備份MySQL數據庫

目的:mysql

192.168.1.2服務器對192.168.1.1服務器上的MySQL數據庫進行備份。sql

必須知足的條件:shell

一、在192.168.1.1服務器上建立專門用來備份的數據庫帳號,並賦予相應的權限:數據庫

mysql> grant select,lock tables on *.* to 'operator'@'192.168.%.%' identified by '123456';   
#備份數據庫須要帳號具備查看錶和鎖定表的權限

二、在192.168.1.2服務器上使用該帳號進行手工備份,測試是否能夠備份成功:vim

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

編寫shell腳本:bash

[root@localhost ~]# mkdir -p /opt/backup             #建立備份後的存放目錄
[root@localhost ~]# vim mysqlbak.sh                  #編寫shell腳本

#!/bin/bash
#定義數據庫鏈接、目標信息庫等信息:
user="operator"       #定義用戶名帳號
pass="123456"        #密碼
host="192.168.1.1"          #目標主機
conn=" -u $user -p$pass -h $host"
data1="test1"             #備份目標庫
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            #賦予該腳本執行權限
[root@localhost ~]# ./mysqlbak.sh             #執行腳本測試是否備份成功
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

設置計劃任務:ide

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

[root@localhost backup]# systemctl status crond             #確保crond服務已運行
● 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

齊活...................工具

相關文章
相關標籤/搜索