Zabbix が MySQL のマスター/スレーブ状態を監視する方法の詳細な説明

Zabbix が MySQL のマスター/スレーブ状態を監視する方法の詳細な説明

MySQLマスタースレーブを設定した後、スレーブの状態が正常かどうかわからないことが多く、例外が発生したときにすぐにわからないことがあります。ここでは、シェルスクリプトとzabbixを組み合わせて監視とアラームを実現できます。

一般的に、MySQL のスレーブの実行状態は、Slave_IO_Running スレッドと Slave_SQL_Running スレッドが正常かどうかをチェックすることで確認します。これは、コマンド「show slave status\G;」を使用して確認できます。ここでは、これら 2 つの値に基づいて判断を行います。

エージェント側のスクリプトの作成と構成

注: すべてのzabbix関連スクリプトを/etc/zabbix/script/ディレクトリに配置しました。以下はすべてzabbixの監視側で操作され、上記のデータベースはMySQLマスタースレーブのスレーブに属しています。

1) スクリプト

[root@srt-xt ~]# cd /etc/zabbix/script/
[root@srt-xt /etc/zabbix/script]# cat mysql_slvae_status.sh 
#!/bin/bash
#Desc: マスタースレーブ同期情報を取得し、マスタースレーブが異常かどうかを判断し、それをZabbixに送信するために使用されます
#日付: 2019-06-06
#by:Lee-YJ
USER="root"
パスワード="nae3eabo9naeli1Oov1a"
名前=$1
関数IO {
  Slave_IO_Running=`mysql -u $USER -p$PASSWD -e "show slave status\G;" 2> /dev/null |grep Slave_IO_Running |awk '{print $2}'`
  [ $Slave_IO_Running == "Yes" ]の場合;
    エコー0 
  それ以外
    エコー1 
  フィ
}
関数SQL{
  Slave_SQL_Running=`mysql -u $USER -p$PASSWD -e "show slave status\G;" 2> /dev/null |grep Slave_SQL_Running: |awk '{print $2}'`
  [ $Slave_SQL_Running == "Yes" ]の場合;
    エコー0 
  それ以外
    エコー1 
  フィ
}
$NAMEの場合
  io)
    IO
  ;;
  sql)
    構文
  ;;
  *)
    echo -e "使用法: $0 [io | sql]"
エサック

2) 設定ファイルを修正し、上記で記述したスクリプトのパスを指定する自己設定ファイルを作成します。

[root@srt-xt ~]# cd /etc/zabbix/zabbix_agentd.d/ 

[root@srt-xt /etc/zabbix/zabbix_agentd.d]# cat ユーザーパラメータ_mysql_slave.conf 
# MySQLスレーブのステータスを取得 UserParameter=mysql.slave[*],/etc/zabbix/script/mysql_slvae_status.sh $1

3) zabbix-agentを再起動する

[root@srt-xt /etc/zabbix/zabbix_agentd.d]# /etc/init.d/zabbix-agentを再起動します

4) zabbix-server でテストして、値が正常に取得できるかどうかを確認します。上記のスクリプトによると、ここでの 0 は正常、1 は異常を意味します。

[root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[sql]
0
[root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[io]
0

サーバー側のWeb構成

1) Slave_IO_Runningスレッド監視項目を構成する

2) Slave_SQL_Runningスレッド監視項目を構成する

3) Slave_IO_Runningスレッドのトリガーを設定する

4) Slave_SQL_Runningスレッドのトリガーを設定する

5) トリガーアクションを設定する

実行するアクションを設定する(管理者にメッセージを送信する)

構成ステータスの回復操作(管理者へのメッセージも送信)

最後に監視項目を確認します

この時点で、MySQL マスタースレーブスレーブのステータス監視は完了です。

要約する

以上が、編集者が紹介したZabbixによるMySQLのマスタースレーブ状態監視方法についての詳細な説明です。皆様のお役に立てれば幸いです。ご質問がございましたら、メッセージを残していただければ、編集者がすぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。
この記事が役に立ったと思われた方は、ぜひ転載していただき、出典を明記してください。ありがとうございます!

以下もご興味があるかもしれません:
  • Zabbixを使用してMySQLを監視する方法
  • Zabbixは複数のmysqlプロセスの監視を実装します
  • Zabbix を使用して Nginx/Tomcat/MySQL を監視する方法の詳細なチュートリアル
  • Zabbix の Percona プラグインを使用して MySQL を監視する方法
  • Zabbix 2.4.5 には MySQL 監視設定チュートリアルが付属しています
  • MySQLを監視するためのZabbixのインストールと設定に関する基本的なチュートリアル
  • Zabbix は MySQL インスタンス メソッドを監視します

<<:  Vue のスロットとフィルターの詳細な説明

>>:  Nginx のリロード プロセスの背後にある真実を探る

推薦する

docker run 起動パラメータ コマンドを表示する方法 (推奨)

runlike を使用してコンテナの docker run 起動パラメータを表示します。 pipを...

mysql 8.0.15 winx64 解凍バージョン グラフィック インストール チュートリアル

システムをインストールした後、毎回いくつかのソフトウェアを再インストールする必要があります。ソフトウ...

HTMLページが3秒後に自動的にジャンプする3つの一般的な方法

実際には、N 秒後にページを自動的にジャンプさせるにはどうすればよいかという問題によく遭遇します。私...

ウェブページ制作時のコードコメントの書き方

<br />私の仕事で使用しているアノテーションの書き方の基準をまとめました。技術的な内...

IDEA が docker を統合して springboot プロジェクトを展開するプロセス全体

目次1. IDEAはdockerプラグインをダウンロードします2. クラウドサーバーDocker 2...

JavaScript 配列の include と Reduce の基本的な使用法

目次序文配列.プロトタイプ.includes文法パラメータ戻り値例配列プロトタイプの削減文法パラメー...

WIN10 での JDK インストールと環境変数の設定手順 (詳細版)

目次1. JDKをダウンロードする(例としてjdk1.8.0を使用する) 2. JDK をインストー...

CSSは高さを設定せずにdivを完全に中央に配置することを実現します

必要とする本文の下のdivは垂直方向に中央揃えになっていますdiv 内のテキストを垂直中央に配置する...

MAC で MySQL の初期パスワードを変更する方法

問題の説明: Macを購入し、初めてMySQLをインストールしました。初期パスワードが分かりません。...

after疑似要素を使用して中空の三角矢印とXアイコンを実装する例

フロントエンドのデザイン案では、「X」や「>」の形をした閉じるボタンや、他の 3 方向の白抜き...

Vue は Tencent Map を統合して API を実装します (デモ付き)

目次執筆の背景プロジェクトの説明事前準備注記執筆の背景以前のプロジェクトではTencent Maps...

Vue コンポーネント (Vuex を含む) 間の値の転送に関する簡単な説明

目次父から息子へ:息子から父へ: Vuex を使用せずにコンポーネント間で値を渡す方法は、親から子、...

HTML のタイトル、段落、改行、水平線、特殊文字についての簡単な説明

タイトルXML/HTML コードコンテンツをクリップボードにコピー< h1 >第 1 レ...

HTML Web ページにおける URL の表現

HTML では、一般的な URL はさまざまな方法で表現されます。相対 URL:コードをコピーコード...

一般的な CSS プロパティのブラウザ互換性の概要 (推奨)

CSS プロパティのブラウザ互換性をまとめる必要があるのはなぜですか?使用する際は、Can I U...