MySQL pt-slave-restart ツールの使い方の紹介

MySQL pt-slave-restart ツールの使い方の紹介

MySQL マスター スレーブ レプリケーション環境を設定する場合、マスター データベースとスレーブ データベースの両方でユーザーのアカウント パスワードを初期化する必要があるシナリオに遭遇することがよくあります。通常の状況では、ユーザー情報をインポートする前に、マスター データベースとスレーブ データベースの両方でセッション レベルの binlog をオフにする必要があります。

ただし、セッションレベルのバイナリログを閉じるという事前アクションが無視される場合もあります。たとえば、GTIDベースのレプリケーションモードでは、マスターライブラリとスレーブライブラリがユーザーのアカウントとパスワード情報を直接インポートします。マスターライブラリとスレーブライブラリは、アカウントとパスワードのトランザクションを独自のGTIDに記録します。このとき、GTID方式を使用してレプリケーションを構築すると、エラーが発生します。スレーブライブラリにはすでにアカウントがあるため、マスターライブラリからスレーブライブラリに同期されたユーザー情報にエラーが発生し、ユーザーがすでに存在することを示します。この場合、マスターライブラリからコピーされたユーザーをスレーブライブラリに作成するためのSQL文をスキップする必要があります。

GTID モードでは、次の方法でトランザクションをスキップできます。

奴隷を停止します。
gtid_next=xxxxx を設定します。
始める;
専念;
gtid_next=自動を設定します。
スレーブを起動します。

ただし、トランザクションが多数ある場合は、1 つずつスキップすることはできません。同じエラーを一括でスキップする必要があります。これを処理する方法はいくつかあります。

MySQL レプリケーション問題の 3 つのパラメータの紹介

それぞれslave_skip_errorsパラメータまたはslave_exec_modeパラメータを調整します。

今日は、pt-slave-restart ツールを使用してトランザクションをスキップする別の方法を見ていきます。コマンドは次のとおりです。

./pt-スレーブ再起動 -uroot -proot123 --error-numbers=1062

このコマンドは分かりやすいです。エラー コードを明確に記述してスキップするだけです。多くの情報が出力されます。デフォルトでは、出力される内容は、タイムスタンプ、接続情報、リレー ログ ファイル、リレー ログの位置、および最後のエラー番号です。例えば:

2020-09-22T00:59:09 P=3306、h=192.168.7.194、p=...、u=ルート リレービン.000005 369 1032
2020-09-22T00:59:09 P=3306、h=192.168.7.194、p=...、u=ルート リレーbin.000005 726 1032
2020-09-22T00:59:09 P=3306、h=192.168.7.194、p=...、u=ルート リレービン.000005 1085 1032
2020-09-22T00:59:09 P=3306、h=192.168.7.194、p=...、u=ルート リレービン.000005 1444 1032
2020-09-22T00:59:09 P=3306、h=192.168.7.194、p=...、u=ルート リレービン.000005 1800 1032

--verbose オプションを使用してさらに情報を追加したり、--quiet オプションを使用してすべての出力を抑制したりできます。

注記:

マルチスレッド レプリケーション (slave_parallel_workers > 0) を使用する場合、pt-slave-restart はトランザクションをスキップできません。 pt-slave-restart は、GTID イベントの失敗したトランザクションを実行した特定のスレーブ スレッドを特定できません。

使用する必要がある場合は、マルチスレッドレプリケーションのワーカーを一時的にシャットダウンしてください。

pt-slave-restart のその他のパラメータについては、pt-slave-restart --help コマンドを使用して表示するか、次の共通パラメータ リストを参照してください。

--always : 手動で停止した場合でも、スレーブ スレッドを停止しません --ask-pass : パスワード入力が背後の開発者に覗き見されるのを防ぐために、-p コマンドを置き換えます --error-numbers : スキップするエラーを指定します。, で区切ることができます --error-text : エラー メッセージに基づいて一致してスキップします --log : ファイルに出力します --recurse : マスター側で実行し、スレーブ側を監視します --runtime : ツールが終了する前に実行される時間。デフォルトは秒、m=分、h=時間、d=日

--slave-user --slave-password : マスター側から実行するときに使用するスレーブ データベースのアカウントとパスワード --skip-count : 一度にスキップするエラーの数。大胆であれば、より大きな数を設定できます。指定しない場合、デフォルトは 1 です --master-uuid : カスケード レプリケーションの場合、上位または上位トランザクションのエラーをスキップするように指定します --until-master : 指定された master_log_pos、ファイル位置に到達したら停止します。形式: "file:pos"

--until-relay : 上記と同じですが、relay_logの位置に基づいて停止します

上記は、MySQL pt-slave-restart ツールの使用方法の紹介の詳細な内容です。MySQL pt-slave-restart ツールの使用方法の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • MySQLサーバーは--read-onlyオプションで実行されているため、このステートメントを実行できません
  • mysql データベースmysql: [エラー] 不明なオプション ''--skip-grant-tables''
  • MySQL ビューの一貫性を確保する方法の詳細な説明 (チェック オプション付き)
  • MySQL に絵文字を保存するときに表示されるエラー メッセージ「java.sql.SQLException: 文字列値が正しくありません:'\xF0\x9F\x92\xA9\x0D\x0A...'」の解決方法
  • MySQL の NULL と空の文字列
  • ODBC経由でMySQLとPHPを任意のデータベースに接続する例
  • Ubuntu で apt-get を使用して mysql をインストールおよび完全にアンインストールする方法の詳細な説明
  • AES_ENCRYPT() と AES_DECRYPT() を使用して MySQL を暗号化および復号化する正しい方法の例
  • mysqlサーバーは--skip-grant-tablesオプションで実行されています
  • pt-heartbeat を使用して MySQL レプリケーションの遅延を監視する方法の詳細な説明

<<:  flex-grow、flex-shrink、flex-basis、9グリッドレイアウトを理解する

>>:  クラウドネイティブテクノロジーKubernetesスケジューリングユニットポッドの使用の詳細な説明

推薦する

vuexサードパーティパッケージを使用してデータの永続性を実装する方法

目的: vuex で管理されている状態データを同時にローカルに保存できるようにします。独自のストレー...

Vue2.x の応答性の簡単な説明と例

1. Vue レスポンシブの使用法を確認する​ Vue の応答性は、私たち全員がよく知っています。 ...

HTML の title 属性を正しく使用するためのヒント

コンテンツを携帯電話、タブレット、支援技術のユーザーから非表示にし、キーボードのユーザーにのみ表示す...

Linuxアカウントファイル制御管理の詳細な手順

Linux システムでは、ユーザーが手動で作成したさまざまなアカウントに加えて、システムまたはプログ...

jQueryのanimateアニメーションメソッドとアニメーションキューイング問題の解決方法の詳しい説明

目次animate() アニメーションメソッドアニメーションキューイングdelay() メソッドアニ...

ウェブページ作成によく使われる英語フォント

アリアルArial は、多くの Microsoft アプリケーションとともに配布されるサンセリフ T...

Docker が占有するディスク領域をクリーンアップする方法

Docker は多くのスペースを占有します。コンテナを実行したり、イメージを取得したり、アプリケー...

MySQL公式エクスポートツールmysqlpumpの使用

目次導入説明書実際の経験長所と短所総括する導入mysqlpump は mysqldump の派生です...

JavaScript でピンボール ゲームの Web バージョンを実装する

参考までに、JavaScriptのオブジェクトとメソッドを使用して実装されたWebピンボールゲームを...

ウェブページのメモリとCPU使用量を削減する方法

<br />Web ページによっては、サイズは大きくないように見えても開くのに非常に時間...

TSオブジェクトのスプレッド演算子とレスト演算子の詳細な説明

目次概要オブジェクトの残り属性オブジェクトの拡張プロパティオブジェクトの浅いコピーを作成するkeyo...

MySQL マスタースレーブレプリケーション切断の一般的な修復方法

目次01 問題の説明02 ソリューション1. 他のスレーブライブラリを見つけてすぐに置き換える2. ...

docker ポートを追加して dockerfile を取得する方法

DockerイメージからDockerfileを取得する docker 履歴 --format {{....

MySQL IDは1から増加し始め、不連続IDの問題を素早く解決します

mysql idは1から始まり、不連続なidの問題を解決するために自動的に増加します。強迫性障害の私...

MySQL テーブルをコピーする 3 つの方法 (要約)

テーブル構造とそのデータをコピーする次のステートメントは、データを新しいテーブルにコピーします。注:...