linux使用mysqldump+expect+crontab實現mysql周期冷備份思緒詳解_虹口區網賺兼職

 

這篇文章主要先容了linux使用mysqldump+expect+crontab實現mysql周期冷備份,本文給人人先容的異常詳細,對人人的學習或事情具有一定的參考借鑒價值,需要的同夥可以參考下

目錄

一、遇到的問題

二、思緒

三、代碼

一、遇到的問題

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

二、思緒

建立一個utils文件,內里存放shell劇本,包羅mysqldump、scp等下令

使用expect劇本,執行utils內的劇本,併為其自動輸入密碼

最後使用驅動劇本,執行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}

SEO大師和SEO小白的區別

經驗從來不是憑空而來的,而是經過千百次的實踐與失敗換來的,SEO大師之所以稱之為大師,並不完全是因為他們的聰明智慧,而是經過無數次失敗后掌握了寶貴的經驗,挺過來的SEO小白就是SEO大師,挺不過來依然是小白。

足球比分竞猜-2019-2020赛季五大联赛:权门优势继续扩大

  进入8月份,欧洲五大联赛将依次拉开帷幕。最近几年,欧洲豪门优势逐渐凸显,意甲尤文已经收获8连冠、德甲拜仁已经7连冠、法甲大巴黎最近7个赛季6次夺冠、西甲三足鼎立、英超曼城两连冠……

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

(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} }

(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:

(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周期冷備份內容請搜索劇本之家以前的文章或繼續瀏覽下面的相關文章希望人人以後多多支持劇本之家!

泉源:劇本之家

鏈接:https://www.jb51.net/article/197861.htm

申請創業報道,分享創業好點子。,配合探討創業新機遇!

域名年齡和SEO排名有關係嗎

域名年齡和SEO排名有沒有關係主要在於域名的有效使用時間,在同等條件下對比,一直在使用的域名肯定要比斷斷續續使用的域名權重更高。

Author: 狗蛋
狗蛋的个人中心,这里没有什么。