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 このコマンドは分かりやすいです。エラー コードを明確に記述してスキップするだけです。多くの情報が出力されます。デフォルトでは、出力される内容は、タイムスタンプ、接続情報、リレー ログ ファイル、リレー ログの位置、および最後のエラー番号です。例えば:
--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 の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: flex-grow、flex-shrink、flex-basis、9グリッドレイアウトを理解する
>>: クラウドネイティブテクノロジーKubernetesスケジューリングユニットポッドの使用の詳細な説明
1. my.cnfを変更する #全体的な効果としては、グローバルがオンになっている場合はテーブルとロ...
テーブルの欠点1. テーブルは他の HTML タグよりも多くのバイトを占有します。 (ダウンロード時...
目次01 InnoDBレプリカセットの紹介02 InnoDBレプリカセットの制限03 導入前に知って...
MySQL を頻繁に使用する人は、次のような状況に遭遇する可能性があります。 1. フィールド タ...
目次UIデザインEcharts の例の効果序文サンプルコード最終結果UIデザイン Echarts の...
CSS では、テキストは私たちが毎日扱う最も一般的なものの 1 つです。テキストの場合、テキストの装...
説明: 指定された時間内に前のノードのコンテンツを置き換えるタイマーを設定します。 1. キーコード...
目次1. ユニットテストはなぜ必要なのでしょうか? 2. ユニットテストの書き方3. テストツール4...
赤とピンク、およびそれらの 16 進コード。 #990033 #CC6699 #FF6699 #FF...
Cerebro は、Elasticsearch バージョン 5.x より前の Elasticsear...
1. パスワードを変更する1. 一般ユーザーのパスワードを変更する パスワード現在のパスワードを入力...
IE8 の新機能 Web スライス (Web スライス) Microsoft は 3 月 20 日...
1. データベースのタイムゾーンを確認する '%time_zone' のような変数を...
データベースはスロークエリログを有効にします設定ファイルを変更する設定ファイルmy.iniに次の2つ...
1. トランザクション特性(ACID) (1)原子性トランザクションに関係するプログラムによって実行...