Linuxでmysqlの定期的なコールドバックアップを実装するためにmysqldump+expect+crontabを使用するアイデアの詳細な説明

Linuxでmysqlの定期的なコールドバックアップを実装するためにmysqldump+expect+crontabを使用するアイデアの詳細な説明

1. 遭遇した問題

私たちは皆、mysqldump を使用した後、mysql パスワードを手動で入力する必要があることを知っています。そのため、定期的なバックアップを実現するために crontab で直接 mysqldump を使用することはできません。実際、expect スクリプトを使用してパスワードを自動的に入力することで、真の定期バックアップを実現できます。 expect が何なのか分からない場合は、まずこの記事を読むことをお勧めします: https://www.jb51.net/article/197865.htm

2. アイデア

  1. mysqldump、scp、その他のコマンドを含むシェルスクリプトを保存するための utils ファイルを作成します。
  2. expectスクリプトを使用して、utilsでスクリプトを実行し、パスワードを自動的に入力します。
  3. 最後に、ドライバースクリプトを使用してexpectを実行し、必要なパラメータをスクリプトに渡します。

考え方は次のとおりです。

ここに画像の説明を挿入

3. コード

3.1. 単一マシンのコールドバックアップ

(1) mysqldumpシェルスクリプト
バックアップ.sh:

#!/bin/bash

mysql_ユーザー名=$1
バックアップデータベース=$2
バックアップパス=$3

mysqldump -u ${mysql_username} -p --databases ${backup_databases} > ${backup_path}

(2)mysqldumpのexpectスクリプトを実行すると、mysqlコードを自動的に入力することができます。
シングルコールドバックアップサービス.exp:

#!/usr/bin/期待する

タイムアウト5を設定

#ローカル情報を設定する set mysql_username [lindex $argv 0] 
バックアップデータベースを設定する [lindex $argv 1] 
バックアップパスを設定する [lindex $argv 2] 

#utils パス utils_path /home/hadoop/backup_script/utils を設定します

bash ${utils_path}/backup.sh ${mysql_username} ${backup_database} ${backup_path} を起動します


期待する {
	"*assword*" {send "nimabidecao1\r"} #パスワードを入力}
EOFを期待する

(3)スクリプトを駆動し、expectを実行します。必要なパラメータを渡すことができます。
single_cold_backup_service_driver.sh:

#!/bin/bash

#ここでのデータはmysql_username=rootと記述できます
バックアップデータベース=学校
バックアップパス=$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エディターに入ります: crontab -e
以下を入力してください:

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

ローカルバックアップパス=$1
別のユーザー=$2
別のIP=$3
別のバックアップパス=$4

scp ${local_backup_path} ${another_user}@${another_ip}:${another_backup_path}

(2)mysqldumpのexpectスクリプトを実行すると、mysqlコードを自動的に入力することができます。
ダブルコールドバックアップサービス.exp:

#!/usr/bin/期待する

タイムアウト5を設定

#ホスト情報セット mysql_username [lindex $argv 0] 
バックアップデータベースを設定する [lindex $argv 1] 
バックアップパスを設定する [lindex $argv 2] 

#スレーブ情報セットslave_user [lindex $argv 3]
slave_ip を設定する [lindex $argv 4]
slave_backup_path を設定する [lindex $argv 5]

#utils パス utils_path /home/hadoop/backup_script/utils を設定します


bash ${utils_path}/backup.sh ${mysql_username} ${backup_database} ${backup_path} を起動します

期待する {
	"*assword*" {send "nimabidecao1\r"} #パスワードを入力}

bash ${utils_path}/scp.sh ${backup_path} ${slave_user} ${slave_ip} ${slave_backup_path} を起動します

期待する {
  "*assword*" {send "nimabidecao1\r"} #パスワードを入力}

EOFを期待する

(3)スクリプトを駆動し、expectを実行します。必要なパラメータを渡すことができます。
double_cold_backup_service_driver.sh:

#!/bin/bash

#ローカルマシン情報 mysql_username=root
バックアップデータベース=学校
バックアップパス=$HOME/backup_data/${backup_databases}.sql

#スレーブ情報 slave_user=meizhaowei
スレーブIP=172.20.10.14
スレーブバックアップパス=バックアップデータ/doule_cold_backup_data/${バックアップデータベース}.sql


# 絶対パスの書き込みを実行します。期待値は $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時にバックアップを実行することを意味します

Linux で mysqldump+expect+crontab を使用して MySQL の定期コールド バックアップを実装する方法についての説明はこれで終わりです。MySQL の定期コールド バックアップの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL スケジュール バックアップ ソリューション (Linux crontab を使用)
  • Linux 6.7 に付属する mysql-libs* crontab コマンドがアンインストール後に使用できなくなる理由の分析
  • Linux での crontab スケジュール バックアップの例を使用した MySQL スケジュール バックアップ
  • Linux システムで crontab を使用して MySQL データベースを定期的にバックアップする方法

<<:  Vueプロジェクトはログインと登録の効果を実現します

>>:  Dockerコミットの使い方の詳しい説明

推薦する

DockerにRocketMQをインストールするための実装手順

目次1. 画像を取得する2. ブローカーサーバーを作成する3. ブローカーを作成する4. Rocke...

17 個の JavaScript ワンライナー

目次1. DOMとBOM関連1. 要素にフォーカスがあるかどうかを確認する2. 要素の兄弟ノードをす...

HTML は、Web ページの作成者が学習して習得しなければならないものです。

HTML を学ぶメリットは何ですか? 1: ウェブサイトやブログのウェブ構造を簡単に変更できます。...

JavaScript のガベージコレクションの仕組みの詳細な説明

目次ガベージコレクション (GC) はなぜ必要なのでしょうか?ガベージコレクションとは廃棄物の発生ガ...

MySQL 5.7 解凍版のインストール、アンインストール、および文字化けしたコードの問題のグラフィック解決

1. 解凍版のインストール(1)圧縮パッケージをダウンロードし、ディスクの場所に解凍します。圧縮パッ...

JSで実現したページサイドバーの効果に関する研究

目次発見: ディスプレイアニメーションの応用実装:記事の1行目を表示する効果を実現する方法実際、その...

SpringBoot アプリケーションの Docker デプロイメントの実装手順

目次序文DockerファイルDockerfile とは何ですか? Dockerfile 構文Spri...

Win10 での MySQL 8.0.16 のインストールと設定のチュートリアル

1. MySQL 8.0.16を解凍する次の図に示すように、解凍後にdadaフォルダとmy.ini構...

ネイティブ JS で音楽プレーヤーを実装するためのサンプル コード

この記事では主に、次のように共有されるネイティブ JS 音楽プレーヤーのサンプル コードを紹介します...

ウェブページが自動的にデュアルコアブラウザの高速モードを呼び出すようにします(Webkit)

コードサンプルヘッドタグにコード行を追加します: XML/HTML コードコンテンツをクリップボード...

MySQLデータベースのパスワードを忘れた場合の解決策

先ほど MySQL パスワードを設定したのに、外食したり荷物を受け取ったりするときにパスワードを忘れ...

CSS3の3D効果を使って立方体を作成する

CSS3 の 3D 効果を使用して立方体を作成する方法を学ぶと、3D シーンの回転と変位のプロパティ...

MySQL 8.0.26 のインストールとアンインストールの完全なステップバイステップの記録

目次序文1. インストール1.公式サイトからダウンロード2. 構成を作成する3. MySQLを初期化...

CSS 複合セレクタの具体的な使用法

交差点セレクター交差セレクターは、直接接続された 2 つのセレクターで構成されます。最初のセレクター...

Linuxのpasswdコマンドの使用

1. コマンドの紹介passwd コマンドは、ユーザー パスワード、アカウント ロック、パスワードの...