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でマウススライドによる愛の拡散効果を実現

推薦する

初心者でもjsのtypeofとinstanceofの違いを理解できます

目次1. 型2. インスタンス3. 違い1. 型typeof 演算子は、評価されていないオペランドの...

動的な色切り替えの実装コードをサポートするために、CSS で SVG 画像を参照します。

表示する svg 画像を追加すると、React はファイルが見つからないというメッセージを表示します...

WebWorkerはJavaScriptサンドボックスの詳細をカプセル化します

目次1. シナリオ2. IJavaScriptShadowboxを実装する2.1 メインスレッドの実...

CSS ボックスの折りたたみに対する 5 つの解決策

まず、ボックスコラプスとは何でしょうか?親ボックスの内側にあるべき要素が外側にあります。第二に、箱は...

JavaScript の Strict モードの詳細な説明

目次導入厳密モードの使用厳格モードの新機能例外を強制的にスローする変数の使用を簡素化する議論を単純化...

Vue を使用した Amap アプリケーション開発のベスト プラクティス

目次序文非同期読み込みパッケージコンポーネントコンポーネントの使用インターフェースをカスタマイズする...

HTML コード内のスペースと空白行についての簡単な説明

HTML コード内の連続するスペースまたは空白行 (改行) はすべて 1 つのスペースとして表示され...

HTML 特殊文字エンコーディング CSS3 コンテンツに関する簡単な説明:「私は特別なシンボルです」

プロジェクトで使用されている特殊文字とアイコンHTMLコードXML/HTML コードコンテンツをクリ...

JSは単純なフィルタリングから複数条件のフィルタリングまで配列フィルタリングを実装します

目次単一条件単一データフィルタリング単一条件複数データフィルタリング複数の条件付きデータフィルタリン...

JS における ES6 継承と ES5 継承の違い

目次継承ES5 プロトタイプ継承ES6 クラス継承両者の違いES5プロトタイプ継承の内部実装ES6 ...

WHMCS V7.4.2 グラフィカル インストール チュートリアル

1. はじめにWHMCS は、ユーザー管理、請求書の支払い、ヘルプ サービスなど、オンライン ビジネ...

プライベートウェアハウス(レジストリとハーバー)を構築するためのDockerの実装

使用される Docker イメージが増えるにつれて、イメージを保存する場所、つまりウェアハウスが必要...

Linux リモート管理と sshd サービス検証の知識ポイントの詳細な説明

1. SSHリモート管理SSH の定義SSH (Secure Shell) は、主にキャラクタ イン...

MySQLパラダイムの使用に関する詳細な説明

1. パラダイムこのパラダイムの英語名は Normal Form であり、1970 年代にリレーショ...

検索ナビゲーションバー付きの CSS サンプルコード

この記事では、CSS を使用して検索機能付きのナビゲーション バーを作成する方法を説明します。以下の...