婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門標簽:湖南人工外呼系統(tǒng)多少錢 申請外呼電話線路 芒果電話機器人自動化 信陽穩(wěn)定外呼系統(tǒng)運營商 石家莊電商外呼系統(tǒng) 百度地圖圖標標注中心 廣東人工電話機器人 日照旅游地圖標注 南通自動外呼系統(tǒng)軟件

一、遇到的問題

我們使用過mysqldump都知道,使用該命令后,需要我們手動輸入 mysql的密碼,那么我們就不能夠直接在crontab中使用mysqldump實現(xiàn)周期備份。其實我們可以使用expect腳本自動輸入密碼,從而實現(xiàn)真正的周期備份。如果你不知道什么是expect,建議先請看這篇文章:https://www.jb51.net/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、單機冷備份

(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

#設置本機信息
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}

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

(4)使用crontab周期執(zhí)行驅(qū)動腳本
進入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、雙機冷備份

(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)執(zhí)行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)驅(qū)動腳本,執(zhí)行expect,這里可以傳入需要的參數(shù)
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


#執(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í)行一次備份

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

您可能感興趣的文章:
  • MySQL定時備份方案(利用Linux crontab)
  • Linux6.7卸載系統(tǒng)自帶的mysql-libs* crontab命令不能用了原因分析
  • MySQL定時備份之使用Linux下的crontab定時備份實例
  • Linux系統(tǒng)利用crontab定時備份Mysql數(shù)據(jù)庫方法

標簽:牡丹江 呼和浩特 天津 合肥 惠州 阿里 公主嶺 沈陽

巨人網(wǎng)絡通訊聲明:本文標題《linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份思路詳解》,本文關鍵詞  linux,使用,mysqldump+expect+crontab,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 下面列出與本文章《linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份思路詳解》相關的同類信息!
  • 本頁收集關于linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份思路詳解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 出国| 富蕴县| 夏河县| 红原县| 巫山县| 英超| 祁东县| 大洼县| 博湖县| 苗栗市| 新密市| 古田县| 广汉市| 崇信县| 玉林市| 紫金县| 黄陵县| 和林格尔县| 三原县| 礼泉县| 界首市| 崇文区| 三亚市| 偏关县| 桃园市| 开封市| 平安县| 深州市| 安宁市| 奉化市| 喀喇| 舒兰市| 江陵县| 星座| 堆龙德庆县| 扶风县| 奉节县| 那坡县| 永兴县| 新建县| 北宁市|