亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份思路詳解

 更新時間:2020年10月21日 10:14:07   作者:lendsomething  
這篇文章主要介紹了linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

一、遇到的問題

我們使用過mysqldump都知道,使用該命令后,需要我們手動輸入 mysql的密碼,那么我們就不能夠直接在crontab中使用mysqldump實現(xiàn)周期備份。其實我們可以使用expect腳本自動輸入密碼,從而實現(xiàn)真正的周期備份。如果你不知道什么是expect,建議先請看這篇文章:http://chabaoo.cn/article/197865.htm

二、思路

  1.  創(chuàng)建一個utils文件,里面存放shell腳本,包括mysqldump、scp等命令
  2. 使用expect腳本,執(zhí)行utils內(nèi)的腳本,并為其自動輸入密碼
  3. 最后使用驅(qū)動腳本,執(zhí)行expect,在該腳本里面?zhèn)魅胄枰膮?shù)

思路如下:

在這里插入圖片描述

三、代碼

3.1、單機(jī)冷備份

(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)執(zhí)行mysqldump的expect腳本,能幫助我們自動輸入mysql代碼
single_cold_backup_service.exp:

#!/usr/bin/expect

set timeout 5

#設(shè)置本機(jī)信息
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)驅(qū)動腳本,執(zhí)行expect,這里可以傳入需要的參數(shù)
single_cold_backup_service_driver.sh:

#!/bin/bash

#這里的數(shù)據(jù)就可以寫死了
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}

這里一定要十分注意自己的路徑,強(qiáng)烈建議使用絕對路徑來執(zhí)行

(4)使用crontab周期執(zhí)行驅(qū)動腳本
進(jìn)入crontab編輯:crontab -e
輸入如下內(nèi)容:

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

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


3.2、雙機(jī)冷備份

(1)復(fù)制遠(yuǎn)程文件,用于拷貝本地機(jī)的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)執(zhí)行mysqldump的expect腳本,能幫助我們自動輸入mysql代碼
double_cold_backup_service.exp:

#!/usr/bin/expect

set timeout 5

#主機(jī)信息
set mysql_username [lindex $argv 0] 
set backup_database [lindex $argv 1] 
set backup_path [lindex $argv 2] 

#從機(jī)信息
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)驅(qū)動腳本,執(zhí)行expect,這里可以傳入需要的參數(shù)
double_cold_backup_service_driver.sh:

#!/bin/bash

#本機(jī)信息
mysql_username=root
backup_databases=school
backup_path=$HOME/backup_data/${backup_databases}.sql

#從機(jī)信息
slave_user=meizhaowei
slave_ip=172.20.10.14
slave_backup_path=backup_data/doule_cold_backup_data/${backup_databases}.sql


#執(zhí)行寫絕對路徑
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周期執(zhí)行驅(qū)動腳本

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

意思是:每周1早上9點執(zhí)行一次備份

到此這篇關(guān)于linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份思路詳解的文章就介紹到這了,更多相關(guān)mysql周期冷備份內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • win10安裝zip版MySQL8.0.19的教程詳解

    win10安裝zip版MySQL8.0.19的教程詳解

    這篇文章主要介紹了win10安裝zip版MySQL8.0.19的教程詳細(xì),本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • Mysql 8.0.18 hash join測試(推薦)

    Mysql 8.0.18 hash join測試(推薦)

    這篇文章給大家介紹Mysql 8.0.18 hash join測試的相關(guān)知識,本文通過實例代碼講解,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2019-10-10
  • Linux下mysql的root密碼修改方法

    Linux下mysql的root密碼修改方法

    mysql是我們經(jīng)常在linux或者windows需要用的一種數(shù)據(jù)庫,相信每位程序員們對mysql應(yīng)該都再熟悉不過了,但是有時大腦短路,突然忘記mysql的超級用戶root的密碼,這個時候就要修改個新的密碼了,下面這篇文章就介紹了Linux下mysql的root密碼修改方法,一起來看看吧。
    2017-03-03
  • 阿里云Linux CentOS 7.2下自建MySQL的root密碼忘記的解決方法

    阿里云Linux CentOS 7.2下自建MySQL的root密碼忘記的解決方法

    這篇文章主要介紹了阿里云Linux CentOS 7.2下自建MySQL的root密碼忘記的解決方法,需要的朋友可以參考下
    2017-07-07
  • Ubuntu配置Mysql主從數(shù)據(jù)庫

    Ubuntu配置Mysql主從數(shù)據(jù)庫

    MySQL數(shù)據(jù)庫支持?jǐn)?shù)據(jù)庫的主從復(fù)制功能,因此在集群方面具有其獨特的優(yōu)勢。眾多國內(nèi)外大型網(wǎng)站架構(gòu)體系中,均采用了MySQL的主從數(shù)據(jù)庫配置來實現(xiàn)查詢負(fù)載、數(shù)據(jù)庫熱備等功能。本人在實際的Web項目中也涉及到這一需求,在此將如何配置實現(xiàn)做個簡單小結(jié)。
    2014-07-07
  • MYSQL刪除表中的指定ID數(shù)據(jù)

    MYSQL刪除表中的指定ID數(shù)據(jù)

    有些時候我們需要刪除表中指定ID數(shù)據(jù),主要是接下模糊刪除,需要的朋友可以參考下
    2013-01-01
  • 詳解MySQL中存儲函數(shù)創(chuàng)建與觸發(fā)器設(shè)置

    詳解MySQL中存儲函數(shù)創(chuàng)建與觸發(fā)器設(shè)置

    這篇文章主要為大家詳細(xì)介紹了MySQL中存儲函數(shù)的創(chuàng)建與觸發(fā)器的設(shè)置,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,需要的可以參考一下
    2022-08-08
  • MySQL一些常用高級SQL語句詳解

    MySQL一些常用高級SQL語句詳解

    對?MySQL?數(shù)據(jù)庫的查詢,除了基本的查詢外,有時候需要對查詢的結(jié)果集進(jìn)行處理。例如只取?10?條數(shù)據(jù)、對查詢結(jié)果進(jìn)行排序或分組等等,今天就給大家分享MySQL一些常用高級SQL語句,感興趣的朋友一起看看吧
    2022-06-06
  • mysql關(guān)于排序底層原理解析

    mysql關(guān)于排序底層原理解析

    這篇文章主要介紹了mysql關(guān)于排序底層原理解析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 詳解mysql 獲取當(dāng)前日期及格式化

    詳解mysql 獲取當(dāng)前日期及格式化

    本篇文章主要介紹了mysql 獲取當(dāng)前日期及格式化,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-12-12

最新評論