1.発生した問題
mysqldumpを使用した後、このコマンドを使用した後にmysqlパスワードを手動で入力する必要があることは誰もが知っています。そのため、crontabでmysqldumpを直接使用して定期的なバックアップを実装することはできません。実際、expectスクリプトを使用してパスワードを自動的に入力し、真の定期的なバックアップを実現できます。何が期待できるかわからない場合は、最初にこの記事を読むことをお勧めします:https://blog.csdn.net/lendsomething/article/details/109066545
2、アイデア
- mysqldump、scp、その他のコマンドを含むシェルスクリプトを保存するためのutilsファイルを作成します
- expectスクリプトを使用してutilsでスクリプトを実行し、そのパスワードを自動的に入力します
- 最後に、ドライバースクリプトを使用し、expectを実行して、スクリプトで必要なパラメーターを渡します。
アイデアは次のとおりです。
三、コード
3.1、スタンドアロンのコールドバックアップ
(1)mysqldumpのシェルスクリプト
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 -e
するには、crontabと入力します。次のように入力します。
0 9 * * 1 bash /home/hadoop/backup_script/single_cold_backup/single_cold_backup_driver.sh
手段:毎週午前9時にバックアップを実行し
ます。必要な時間を決定する場合は、次のWebサイトにアクセスできます: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
手段:毎週午前9時にバックアップを実行します