MySQLを安全にシャットダウンする方法

MySQLを安全にシャットダウンする方法

MySQL サーバーをシャットダウンする場合、シャットダウン方法に応じてさまざまな問題が発生する可能性があります。次の手順に従うと、問題の発生を減らすことができます。

1. コピーをやめる

特殊な状況下では、スレーブ ノードが間違った位置から開始しようとする場合があります。このリスクを軽減するには、まず io スレッドを停止して、新しいイベント情報が受信されないようにします。

mysql> スレーブ io_thread を停止します。

SQL スレッドがすべてのイベントを適用した後、SQL スレッドも停止します。

mysql>スレーブステータスを表示\G
mysql> スレーブ sql_thread を停止します。

こうすることで、io スレッドと sql スレッドの位置が一致し、リレー ログには実行されたイベントのみが含まれ、relay_log_info_repository 内の位置情報も最新のものになります。

マルチスレッド レプリケーションが有効になっているスレーブの場合は、レプリケーションをシャットダウンする前にギャップが埋められていることを確認してください。

mysql> スレーブを停止します。
mysql> start slave until sql_after_mts_gaps; #リレーログにギャップを適用
mysql> show slave status\G #sql_threadが停止していることを確認してください
mysql> スレーブを停止します。

2. 長時間実行中のトランザクションをコミット、ロールバック、または強制終了する

1 分間に多くのことが起こる可能性があり、シャットダウン時に InnoDB はコミットされていないトランザクションをロールバックする必要があります。トランザクションのロールバックは非常にコストがかかり、長い時間がかかる可能性があります。トランザクションのロールバックはデータ損失を意味する可能性があるため、閉じるときにトランザクションが開いていないことが理想的です。

読み取り/書き込みデータベースが閉じられている場合は、書き込み操作を事前に他のノードにルーティングする必要があります。まだトランザクションを受信して​​いるデータベースをシャットダウンする必要がある場合、次のクエリは 60 秒以上実行されたセッションに関する情報を出力します。この情報に基づいて、次のステップを決定します。

mysql> SELECT trx_id, trx_started, (NOW() - trx_started) trx_duration_seconds, id processlist_id, user, IF(LEFT(HOST, (LOCATE(':', host) - 1)) = '', host, LEFT(HOST, (LOCATE(':', host) - 1))) host, command, time, REPLACE(SUBSTRING(info,1,25),'\n','') info_25 FROM information_schema.innodb_trx JOIN information_schema.processlist ON innodb_trx.trx_mysql_thread_id = processlist.id WHERE (NOW() - trx_started) > 60 ORDER BY trx_started;
+--------+----------------------+-----------------------+----------+----------+-------+----------------------------+
| trx_id | trx_started | trx_duration_seconds | processlist_id | ユーザー | ホスト | コマンド | 時間 | info_25 |
+--------+----------------------+-----------------------+----------+----------+-------+----------------------------+
| 511239 | 2020-04-22 16:52:23 | 2754 | 3515 | dba | localhost | スリープ | 1101 | NULL |
| 511240 | 2020-04-22 16:53:44 | 74 | 3553 | root | localhost | クエリ | 38 | t1 set name="test" を更新 |
+--------+----------------------+-----------------------+----------+----------+-------+----------------------------+
セット内の 2 行 (0.00 秒)

3. プロセスリストをクリアする

mysql は切断され、シャットダウンしようとしています。手動でmysqlをサポートできます。

アクティブな接続とスリープ状態の接続を表示および終了するには、pt-kill を使用します。現時点では新しい書き込み接続は入ってこないはずです。読み取り接続のみを処理します。

pt-kill --host="localhost" --victims="all" --interval=10 --ignore-user="pmm|orchestrator" --busy-time=1 --idle-time=1 --print [--kill]

ここでは、特定のユーザーによって確立された接続を選択的に除外できます。

4. 最大フラッシュを完了するようにInnoDBを構成する

グローバル innodb_fast_shutdown=0 を設定します。
グローバル innodb_max_dirty_pages_pct を 0 に設定します。
グローバル innodb_change_buffering='none' を設定します。

innodb_fast_shutdown を無効にすると、UNDO ログが消去され、変更バッファがマージされるまで待機する必要があるため、シャットダウン プロセスに数分または数時間かかる場合があります。

シャットダウンを高速化するには、innodb_max_dirty_pages_pct=0 を設定し、次のクエリの結果を監視します。期待値は 0 ですが、MySQL にアクティビティがある場合、これが常に保証されるわけではありません。その後、結果が小さくなり続けない場合は、次の手順に進むことができます。

'%dirty%' のようなグローバル ステータスを表示します。

pmm モニタリングを使用すると、「innodb 変更バッファ」の図を表示できます。

5. バッファプールの内容をダンプする

グローバル innodb_buffer_pool_dump_pct=75 を設定します。
グローバル innodb_buffer_pool_dump_now を ON に設定します。
mysql> 'Innodb_buffer_pool_dump_status' のようなステータスを表示します。
+--------------------------------+--------------------------------------------------+
| 変数名 | 値 |
+--------------------------------+--------------------------------------------------+
| Innodb_buffer_pool_dump_status | バッファー プールのダンプが 200429 14:04:47 に完了しました |
+--------------------------------+--------------------------------------------------+
セット内の1行(0.01秒)

起動時にダンプされたコンテンツをロードするには、パラメータ innodb_buffer_pool_load_at_startup の設定を確認します。

6. ブラシログ

ログをフラッシュします。

これで、mysql をシャットダウンできます。

ほとんどの場合、停止コマンドを実行するだけで、MySQL がシャットダウンして再起動するのは正常です。時々問題が起こります。

以上がMySQLを安全にシャットダウンする方法の詳細です。MySQLを安全にシャットダウンする方法の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • 年末ですが、MySQL パスワードは安全ですか?
  • MySQLデータベースの名前を高速かつ安全に変更する方法(3種類)
  • MySQLプロセスを安全かつ適切にシャットダウンする方法
  • MySQLデータのセキュリティを確保するための提案
  • MySQLインスタンスを安全にシャットダウンする方法
  • MySQL セキュリティ管理の詳細

<<:  Dockerはプロセス操作を管理するためにSupervisorを使用する

>>:  ネイティブJSでマウススライドによる愛の拡散効果を実現

推薦する

CSS スタイルが機能しない (史上最も完全な解決策の概要)

ページを作成するときに、記述した CSS スタイルが有効にならないことがあります。この現象にはさまざ...

Mysql マスタースレーブレプリケーションの注意事項の説明

1. マスター'x@xxxx:x'への接続エラー- 再試行時間: 60 再試行回数:...

vue.js ルーターのネストされたルートの実例

目次序文Vue CLI での設定基本コードVueルーターの登場ネストされたルートの設定要約する序文V...

Apache での ab パフォーマンス テスト結果を分析する

私はパフォーマンス テストを行うために常に Loadrunner を使用してきました。 Loadru...

JavaScript Sandboxについての簡単な説明

序文:サンドボックスといえば、私たちの頭には反射的に上の写真が思い浮かび、すぐに興味がわいてくるかも...

Nest.js 認証検証方法の例

目次0x0 はじめに0x1 RBAC 実装0x2 クレームベースの承認0x3 統合 CASL 0x4...

VMware仮想マシンブリッジによるインターネット相互接続を実現する方法

VMware をインストールして新しい仮想マシンを作成したら、オプション バーの [編集] - [仮...

nginx が動的と静的の分離を実装する方法の例

目次server1にnginxをデプロイするサーバーにlnmpを展開するノード3にhttpdをデプロ...

ab ツールを使用してサーバー上で API ストレス テストを実行します。

目次1 システムスループットの簡単な紹介2 試験方法2.1 クライアントテストツール2.1.1 GE...

uniapp WeChatミニプログラムのグローバル共有を実装するためのサンプルコード

目次グローバル共有コンテンツファイルを作成するファイルをインポートしてグローバルに登録するページ共有...

美しいチェックボックススタイル(複数選択ボックス)はIE8/9/10、FFなどと完全に互換性があります。

恥ずかしながら、このようなよく使われるチェックボックスのスタイルを変更するために、Baidu で長い...

JavaScript の BigIn 関数の共通プロパティをまとめます

目次1. 概要2. 属性1. 数学演算子2. 比較演算子3. ブール演算結論1. 概要BigInt ...

Navicat による MySQL パーティショニングの実践

MySQLのパーティショニングは、非常に大きなテーブルを管理するのに役立ちます。MySQLのパーティ...

ウェブページのCSSの優先順位について詳しく説明します

CSS の優先順位について話す前に、CSS とは何か、CSS が何に使用されるのかを理解する必要があ...

Vue+js 矢印をクリックして画像を切り替える

この記事の例では、矢印をクリックして画像を切り替えるVue + jsの具体的なコードを共有しています...