ホームページ >データベース >mysql チュートリアル >MySQL のバックアップとリカバリ: データを保護する方法
データのバックアップとリカバリは、データベース管理の重要な部分です。すべてのソフトウェアが誤動作したり、ハードウェアが損傷したりして、データの損傷や損失が発生する可能性があるためです。 MySQL データベースを使用している場合は、データを保護するためにデータをバックアップおよび復元する方法を知る必要があります。
MySQL では、次のようなさまざまな方法を使用してバックアップとリカバリを実行できます。
これらの方法については、以下で詳しく説明します。
MySQL の組み込みバックアップおよびリカバリ ツール
MySQL には、mysqldump と mysqlhotcopy という 2 つの組み込みツールが用意されています。どちらのツールもコマンド ラインを使用して操作でき、操作が比較的簡単で、バックアップとリカバリの整合性が保証されます。
mysqldump は、MySQL で最も一般的に使用されるバックアップ ツールの 1 つです。 MySQL サーバーを停止せずにデータベースをバックアップし、元のデータベースとまったく同じ .sql ファイルを生成できます。 mysqldump を使用すると、すべてのデータベースをバックアップするか、特定のデータベースをバックアップするかを選択できます。
mysqldump コマンドを使用してデータベースをバックアップする構文は次のとおりです:
mysqldump -u [用户名] -p [密码] [数据库名] > [备份文件名].sql
例:
mysqldump -u root -p mydatabase > backup.sql
バックアップが完了したら、次の構文を使用して次のことを行うことができます。データベースを復元します:
mysql -u [用户名] -p [密码] [数据库名] < [备份文件名].sql
mysqldump を使用してデータベースを復元するための構文は次のとおりです:
mysql -u [用户名] -p [密码] [数据库名] < [备份文件名].sql
例:
mysql -u root -p mydatabase < backup.sql
mysqlhotcopy は、データベース ディレクトリ全体をバックアップできるバックアップ ツールです。通常、バックアップ速度は mysqldump よりもはるかに高速です。ただし、mysqlhotcopy を使用するには、MySQL サーバーを停止する必要があります。
次は、mysqlhotcopy を使用してデータベースをバックアップするための構文です:
mysqlhotcopy [源路径] -u [用户名] -p [密码] [目标路径]
例:
mysqlhotcopy /var/lib/mysql/mydatabase /backup/mydatabase -u root -p password
次は、mysqlhotcopy を使用してデータベースを復元するための構文です:
cp -r /备份路径/* /MySQL数据库路径/
例:
cp -r /backup/mydatabase/* /var/lib/mysql/mydatabase/
サードパーティのバックアップ ツール
MySQL の組み込みバックアップ ツールに加えて、選択できるサードパーティのバックアップ ツールが数多くあります。例: Xtrabackup、Percona Toolkit など。これらのツールにはそれぞれ長所と短所があるため、ニーズに合ったものを選択する必要があります。多くの場合、サードパーティのバックアップ ツールを使用すると、バックアップとリカバリの操作が高速化されます。
手動バックアップとリカバリ
手動バックアップとリカバリは最も直接的な方法ですが、この方法はシステム管理者の高度なスキルと時間を必要とし、データ ファイルをコピーして実行する必要があります。 。手動バックアップでは、MySQL サーバーを停止し、データベースが存在するディレクトリをコピーしてバックアップを実行する必要があります。
手動バックアップの手順は次のとおりです。
sudo systemctl stop mysql
sudo mv /var/lib/mysql/mydatabase /backup/mydatabase
sudo systemctl start mysql
手動リカバリの手順は次のとおりです。
sudo systemctl stop mysql
sudo cp -R /backup/mydatabase /var/lib/mysql
sudo chown -R mysql:mysql /var/lib/mysql/mydatabase
sudo systemctl start mysql
結論
どのバックアップおよびリカバリ方法を使用する場合でも、次の点に注意する必要があります。
MySQL データベースのバックアップとリカバリは重要であり、次のような事態に直面しても安全を確保できます。データの損失や破損が発生した場合でも、迅速に回復できます。どの方法を使用する場合でも、バックアップの整合性を確保するために、データを定期的にバックアップし、バックアップを別の場所に保存する必要があります。
以上がMySQL のバックアップとリカバリ: データを保護する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。