ホームページ >データベース >mysql チュートリアル >MYSQL 学習の要約 (4): MYSQL のリカバリとバックアップ
#すべてのライブラリをバックアップするには mysqldump を使用します
Mysqldump –opt –master-data –single-transaction –u root –ppassword –all –database > all.sql
パラメーターの説明: --opt がデフォルトのオプションのようです。省略可能です。主な機能は、ライブラリが大きくなりすぎるのを防ぐことです。そうしないと、結果が最初にメモリに置かれるため、問題が発生します
--master-data これは主に、エクスポートされた位置(位置)を表示することです。バイナリ ログ) の結果
--single-transaction これは、読み取りロック付きのフラッシュ テーブルと同様に、innoDB エンジンに関連して機能します。
#mysqldump を使用してデータベースをバックアップします
Mysqldump –u root –ppassword データベース名 > .sql
#mysqldump を使用してテーブルをバックアップします (つまり、1 つのテーブル データをエクスポートします)
Mysqldump –u root –ppassword –databases データベース名 –tables tablename > tablename.sql
#mysqldump を使用してバックアップを圧縮します
Mysqldump –u root – ppassword データベース名 | gzip > データベース名.sql.gz
#mysqldump リカバリ
mysql –u root –ppassword データベース名
mysql に入力して、source /tmp/databasename.sql を実行します
# mysqlhotcopy を使用してライブラリをバックアップします
Mysqlhotcopy –uroot –p=password データベース名 /bakup/backup directory
#mysqlhotcopy を使用して特定のテーブルをバックアップします
Mysqlhotcopy –u root –p=パスワード データベース名./テーブル名/ /backup/バックアップ ディレクトリ
#mysqlhotcopy を使用してライブラリをバックアップし、バックアップ レコードを追加します
Mysqlhotcopy –u root –p=パスワード –checkpoint=hotcopy.checkpoint データベース名 /bakup/バックアップ レコード
パラメーター説明: 各バックアップ実行の記録をホットコピー ライブラリ チェックポイント テーブルに保存します。これは事前に作成する必要があります。 ライブラリとテーブル
例: データベースのホットコピーを作成します。
ホットコピーを使用します。
テーブル チェックポイントを作成します (time_stamp timestamp not null,src) varchar(32),dest varchar(32),msg varcher(255));
#ホットコピーバックアップライブラリを復元
データベースディレクトリをデータベースのデータディレクトリに直接コピーします。ディレクトリの権限に注意してください。
#mysqldump と mysqlhotcopy の違いと個人的な理解
Mysqlhotcopy は MYISAM エンジンのテーブルにのみ適用されます
mysqlhotcopy を使用するには、perl-DBI モジュールと perl-DBD-mysql モジュールをインストールする必要があります
どちらも、次の場合に自動的にテーブルをロックしますそれらは実行されます
Mysqlhotcopy はリカバリ中にバックアップ ファイルをターゲット ディレクトリにコピーして上書きする必要があり、mysqldump はバックアップ ファイルを元のデータベースにインポートする必要があります
#バイナリ ログに基づいたリカバリ
Mysqlbinlog mysql-bin.XXXXX | u root –ppassword // mysql-bin.XXXX バイナリ ログ ファイル全体を復元します
Mysqlbinlog –start-datatime="2014-02-28 10:00:00" –stop-datatime="2014-02-28 12:00 :00" mysql-bin.XXXX | mysql –u root –ppassword //mysql-bin.XXXX の 10 時から 12 時までの一部の操作を復元します
Mysqlbinlog –start-position='3000' –stop-position ='5000' mysql-bin.XXXX | mysql –u root –ppassword // mysql-bin.XXXX の 3000 ~ 5000 の部分を復元します。 mysqlbinlog ツールを使用してバイナリ ログをエクスポートし、場所を見つけることができます。 例: mysqlbinlog /var/mysql-bin.XXXX >/tmp/binlogXXXX.txt