亚洲无日韩码精品,成人国产精品日本在线,人妻无码中文字幕免费视频蜜桃,少妇扒开毛茸茸的b自慰

歡迎光臨官渡區(qū)光晉五金經(jīng)營部!
源頭制造官渡區(qū)光晉五金經(jīng)營部高新技術(shù)企業(yè) 歐盟標(biāo)準(zhǔn) 雙效合一
全國咨詢熱線:010-70090059
熱門關(guān)鍵詞: 汽車電瓶 汽車音響 汽車配件
當(dāng)前位置:主頁 > 新聞資訊 >

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

時間:2025-07-04 02:59:25 來源:pk 點擊:1245 次

這篇文章主要介紹了linux使用mysqldump+expect+crontab實現(xiàn)mysql周期冷備份,使b實本文給大家介紹的非常詳細(xì),對大家的周期學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的冷備路詳朋友可以參考下

目錄

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

一、遇到的份思問題

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

二、思路

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

三、使b實代碼

一、周期遇到的冷備路詳問題

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

二、周期思路

創(chuàng)建一個utils文件,冷備路詳里面存放shell腳本,包括mysqldump、scp等命令

使用expect腳本,執(zhí)行utils內(nèi)的腳本,并為其自動輸入密碼

最后使用驅(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

#運(yùn)行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:

(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)文章希望大家以后多多支持腳本之家!

來源:腳本之家

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

在線客服
聯(lián)系方式

熱線電話

021-22062371

上班時間

周一到周五

公司電話

021-63448209

獲取報價