1. 程式人生 > 資料庫 >linux使用mysqldump+expect+crontab實現mysql週期冷備份思路詳解

linux使用mysqldump+expect+crontab實現mysql週期冷備份思路詳解

一、遇到的問題

我們使用過mysqldump都知道,使用該命令後,需要我們手動輸入 mysql的密碼,那麼我們就不能夠直接在crontab中使用mysqldump實現週期備份。其實我們可以使用expect指令碼自動輸入密碼,從而實現真正的週期備份。如果你不知道什麼是expect,建議先請看這篇文章:https://www.jb51.net/article/197865.htm

二、思路

  1. 建立一個utils檔案,裡面存放shell指令碼,包括mysqldump、scp等命令
  2. 使用expect指令碼,執行utils內的指令碼,併為其自動輸入密碼
  3. 最後使用驅動指令碼,執行expect,在該腳本里面傳入需要的引數

思路如下:

在這裡插入圖片描述

三、程式碼

3.1、單機冷備份

(1)mysqldump的shell指令碼
backup.sh:

#!/bin/bash

mysql_username=$1
backup_databases=$2
backup_path=$3

mysqldump -u ${mysql_username} -p --databases ${backup_databases} > ${backup_path}

(2)執行mysqldump的expect指令碼,能幫助我們自動輸入mysql程式碼
single_cold_backup_service.exp:

#!/usr/bin/expect

set timeout 5

#設定本機資訊
set mysql_username [lindex $argv 0] 
set backup_database [lindex $argv 1] 
set backup_path [lindex $argv 2] 

#utils路徑
set utils_path /home/hadoop/backup_script/utils

spawn bash ${utils_path}/backup.sh ${mysql_username} ${backup_database} ${backup_path}


expect {
	"*assword*" {send "nimabidecao1\r"} #輸入密碼
}
expect eof

(3)驅動指令碼,執行expect,這裡可以傳入需要的引數
single_cold_backup_service_driver.sh:

#!/bin/bash

#這裡的資料就可以寫死了
mysql_username=root
backup_databases=school
backup_path=$HOME/backup_data/${backup_databases}.sql

#執行expect指令碼
expect $HOME/backup_script/single_cold_backup/single_cold_backup_service.exp ${mysql_username} ${backup_databases} ${backup_path}

這裡一定要十分注意自己的路徑,強烈建議使用絕對路徑來執行

(4)使用crontab週期執行驅動指令碼
進入crontab編輯:crontab -e
輸入如下內容:

0 9 * * 1 bash /home/hadoop/backup_script/single_cold_backup/single_cold_backup_driver.sh 

意思為:每週1早上9點執行一次備份
若你想確定自己想要的時間,可以到這個網址:https://crontab-generator.org/ 去點選自己想要的時間


3.2、雙機冷備份

(1)複製遠端檔案,用於拷貝本地機的mysql備份檔案
scp.sh:

#!/bin/bash

local_backup_path=$1
another_user=$2
another_ip=$3
another_backup_path=$4

scp ${local_backup_path} ${another_user}@${another_ip}:${another_backup_path}

(2)執行mysqldump的expect指令碼,能幫助我們自動輸入mysql程式碼
double_cold_backup_service.exp:

#!/usr/bin/expect

set timeout 5

#主機資訊
set mysql_username [lindex $argv 0] 
set backup_database [lindex $argv 1] 
set backup_path [lindex $argv 2] 

#從機資訊
set slave_user [lindex $argv 3]
set slave_ip [lindex $argv 4]
set slave_backup_path [lindex $argv 5]

#utils路徑
set utils_path /home/hadoop/backup_script/utils


spawn bash ${utils_path}/backup.sh ${mysql_username} ${backup_database} ${backup_path}

expect {
	"*assword*" {send "nimabidecao1\r"} #輸入密碼
}

spawn bash ${utils_path}/scp.sh ${backup_path} ${slave_user} ${slave_ip} ${slave_backup_path}

expect {
  "*assword*" {send "nimabidecao1\r"} #輸入密碼
}

expect eof

(3)驅動指令碼,執行expect,這裡可以傳入需要的引數
double_cold_backup_service_driver.sh:

#!/bin/bash

#本機資訊
mysql_username=root
backup_databases=school
backup_path=$HOME/backup_data/${backup_databases}.sql

#從機資訊
slave_user=meizhaowei
slave_ip=172.20.10.14
slave_backup_path=backup_data/doule_cold_backup_data/${backup_databases}.sql


#執行寫絕對路徑
expect $HOME/backup_script/double_cold_backup/double_cold_backup_service.exp ${mysql_username} ${backup_databases} ${backup_path} ${slave_user} ${slave_ip} ${slave_backup_path}

(4)使用crontab週期執行驅動指令碼

0 9 * * 1 bash /home/hadoop/backup_script/double_cold_backup/double_cold_backup_driver.sh

意思是:每週1早上9點執行一次備份

到此這篇關於linux使用mysqldump+expect+crontab實現mysql週期冷備份思路詳解的文章就介紹到這了,更多相關mysql週期冷備份內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!