2 パッシブおよびアクティブエージェントチェック
概要
このセクションでは、ZabbixエージェントおよびZabbixエージェント2によって実行されるパッシブチェックとアクティブチェックの詳細について説明します。
Zabbixは、エージェントとの通信にJSONベースの通信プロトコルを使用しています。
ZabbixエージェントとZabbixエージェント2のプロトコルは、Zabbix 7.0以降で統一されました。ZabbixエージェントとZabbixエージェント2のリクエスト/レスポンスの違いは、"variant"タグの値で表されます。
パッシブチェック
パッシブチェックは、単純なデータ要求です。Zabbix サーバーまたはプロキシが 何らかのデータ(たとえば CPU 使用率)を要求し、Zabbix エージェントが結果を サーバーに返します。
パッシブチェックは非同期で実行されます。1つの要求に対する応答を受信する前に、他のチェックを開始する必要はありません。DNS 解決も同様に非同期です。
エージェントポーラーは、DNS ルックアップで返されたすべてのアドレスへの接続を試みます。これにより、1つの IP アドレスに到達できない場合でも、ポーラーは次に利用可能なアドレスを試行し、接続成功の可能性が高まります。この拡張は Zabbix サーバーとプロキシの両方に適用されます。
非同期チェックの最大同時実行数は 1000 です(MaxConcurrentChecksPerPoller で定義)。
非同期エージェントポーラーの数は StartAgentPollers パラメーターで定義されます。
サーバー要求
ヘッダーとデータ長の定義については、プロトコルの詳細 を参照してください。
{
"request": "passive checks",
"data": [
{
"key": "agent.version",
"timeout": 3
}
]
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| request | string | yes | "passive checks" |
|
| data | array of object | yes | パッシブチェックのアイテム。 | |
| key | string | yes | 展開済みマクロを含むアイテムキー。 | |
| timeout | number | yes | 通信タイムアウト。 | |
エージェント応答
{
"version": "7.4.0",
"variant": 2,
"data": [
{
"value": "7.4.0"
}
]
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| version | string | yes | エージェントのバージョン番号。 | |
| variant | number | yes | エージェントの種類(1 - Zabbix agent、2 - Zabbix agent 2)。 | |
| data | array of object | yes | チェックの結果を含みます。 | |
| value | string | no | チェックが成功した場合のアイテム値。 | |
| error | string | no | チェックが成功しなかった場合のエラーメッセージ。 | |
たとえば、サポートされているアイテムの場合:
- サーバーが TCP 接続を開く
- サーバーが <HEADER><DATALEN>{"request":"passive checks","data":[{"key":"agent.ping","timeout":3}]} を送信する
- エージェントが要求を読み取り、次のように応答する <HEADER><DATALEN>{"version":"7.4.0","variant":2,"data":[{"value":1}]}
- サーバーがデータを処理して、ここでは値 '1' を取得する
- TCP 接続が閉じられる
サポートされていないアイテムの場合:
- サーバーが TCP 接続を開く
- サーバーが <HEADER><DATALEN>{"request":"passive checks","data":[{"key":"vfs.fs.size[/nono]","timeout":3}]} を送信する
- エージェントが要求を読み取り、次のように応答する <HEADER><DATALEN>{"version":"7.4.0","variant":2,"data":[{"error":"Unsupported item key."}]}
- サーバーがデータを処理し、指定されたエラーメッセージとともにアイテムの状態をサポート対象外に変更する
- TCP 接続が閉じられる
古いプロトコルへのフェイルオーバー
Zabbixサーバーまたはプロキシが、プレーンテキストプロトコルを持つ7.2以前のバージョンのエージェントと連携できるように、古いプロトコルへのフェイルオーバーが実装されています。
パッシブチェックは、再起動後またはインターフェース構成が変更された場合に、JSONプロトコル(7.0以降)を使用して実行されます。 応答で有効なJSONが受信されなかった場合(エージェントが "ZBX_NOTSUPPORTED" を送信した場合)、Zabbixはインターフェースを古いプロトコルとしてキャッシュし、再試行としてアイテムキーのみを送信してチェックを行います。
Zabbixサーバー/プロキシは、すべてのインターフェースで毎時新しいプロトコルでの動作を再試行し、必要に応じて古いプロトコルにフォールバックすることに注意してください。
アクティブチェック
アクティブチェックは、より複雑な処理を必要とします。 エージェントは、独立した処理のために、最初にサーバー/プロキシからアイテムやリモートコマンドのリストを取得する必要があります。
アクティブチェックを取得するサーバー/プロキシは、エージェントの設定ファイルの「ServerActive」パラメータに記載されています。 これらのチェックを要求する頻度は、同じ設定ファイルの「RefreshActiveChecks」パラメータで設定します。 ただし、アクティブチェックの更新に失敗した場合は、ハードコードされた60秒後に再試行されます。
Zabbix 6.4以降、エージェント(アクティブモード)は、サーバー/プロキシから2分ごと(デフォルト)に設定の完全なコピーを受信しなくなりました。 代わりに、ネットワークトラフィックとリソース使用量を減らすために、5秒ごと(デフォルト)に増分設定同期が実行され、サーバー/プロキシは、エージェントがまだ受信していない場合、またはホスト設定、グローバルマクロ、グローバル正規表現に何か変更があった場合にのみ設定の完全なコピーを提供します。
エージェントは定期的に新しい値をサーバーに送信します。 エージェントが実行するリモートコマンドを受信した場合、実行結果も送信されます。 アクティブエージェントでのリモートコマンド実行のサポートは、Zabbix agent 7.0からです。
エージェントがファイアウォールの背後にある場合は、アクティブチェックのみを使用することを検討してください。この場合、初期の着信接続を許可するためにファイアウォールを変更する必要がありません。
アイテム一覧の取得
エージェント要求
active checks 要求は、エージェントによって処理される active checks を取得するために使用されます。
この要求は、エージェント起動時に送信され、その後は RefreshActiveChecks の間隔で送信されます。
{
"request": "active checks",
"host": "Zabbix server",
"host_metadata": "mysql,nginx",
"interface": "zabbix.server.lan",
"ip": "159.168.1.1",
"port": 12050,
"version": "7.4.0",
"variant": 2,
"config_revision": 1,
"session": "e3dcbd9ace2c9694e1d7bbd030eeef6e"
}
| Field | Type | Mandatory | Value |
|---|---|---|---|
| request | string | yes | active checks |
| host | string | yes | ホスト名。 |
| host_metadata | string | no | 設定パラメータ HostMetadata または HostMetadataItem のメトリック値。 |
| interface | string | no | 設定パラメータ HostInterface または HostInterfaceItem のメトリック値。 |
| ip | string | no | 設定パラメータ ListenIP が設定されている場合の最初の IP。 |
| port | number | no | 設定パラメータ ListenPort の値が設定されており、かつデフォルトのエージェント待受ポートではない場合の値。 |
| version | string | yes | エージェントのバージョン番号。 |
| variant | number | yes | エージェントの種類(1 - Zabbix agent、2 - Zabbix agent 2)。 |
| config_revision | number | no | 増分設定同期 用の設定識別子。 |
| session | string | no | 増分設定同期 用のセッション識別子。 |
サーバー応答
active checks 応答は、active checks 要求の処理後にサーバーからエージェントへ送信されます。
{
"response": "success",
"config_revision": 2,
"data": [
{
"key": "system.uptime",
"itemid": 1234,
"delay": "10s",
"lastlogsize": 0,
"mtime": 0
},
{
"key": "agent.version",
"itemid": 5678,
"delay": "10m",
"lastlogsize": 0,
"mtime": 0,
"timeout": "30s"
}
],
"commands": [
{
"command": "df -h --output=source,size / | awk 'NR>1 {print $2}'",
"id": 1324,
"wait": 1
}
]
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| response | string | yes | success | failed |
|
| info | string | no | 失敗時のエラー情報。 | |
| data | array of objects | no | active check アイテム。ホスト設定が変更されていない場合は省略されます。 | |
| key | string | no | マクロ展開後のアイテムキー。 | |
| itemid | number | no | アイテム識別子。 | |
| delay | string | no | アイテム更新間隔。 柔軟/スケジューリング間隔は、Zabbix 7.0 以降、Zabbix agent と Zabbix agent 2 の両方でサポートされています。 |
|
| lastlogsize | number | no | アイテム lastlogsize。 | |
| mtime | number | no | アイテム mtime。 | |
| timeout | string | no | アイテムのタイムアウト。 | |
| refresh_unsupported | number | no | サポートされていないアイテムの更新間隔。 | |
| regexp | array of objects | no | グローバル正規表現。 | |
| name | string | no | グローバル正規表現名。 | |
| expression | string | no | グローバル正規表現。 | |
| expression_type | number | no | グローバル正規表現の種類。 | |
| exp_delimiter | string | no | グローバル正規表現の区切り文字。 | |
| case_sensitive | number | no | グローバル正規表現の大文字小文字の区別設定。 | |
| commands | array of objects | no | 実行するリモートコマンド。アクションの operation または手動の script 実行によってリモートコマンドの実行がトリガーされた場合に含まれます。アクティブなエージェント上でのリモートコマンド実行は、Zabbix agent 7.0 以降でサポートされている点に注意してください。古いアクティブエージェントは、active checks のサーバー応答に含まれるリモートコマンドを無視します。 | |
| command | string | no | リモートコマンド。 | |
| id | number | no | リモートコマンド識別子。 | |
| wait | number | no | リモートコマンドの実行モード(アクションの operations からのコマンドでは "0"(nowait)、手動の script 実行からのコマンドでは "1"(wait))。 | |
| timeout | number | no | サーバー/プロキシ 設定におけるリモートコマンド実行タイムアウト。 | |
| config_revision | number | no | 増分設定同期 用の設定識別子。ホスト設定が変更されていない場合は省略されます。ホスト設定が変更された場合は増分されます。 | |
サーバーは success を返さなければなりません。
例:
- エージェントが TCP 接続を開く
- エージェントがチェック一覧を要求する
- サーバーがアイテム一覧と実行するリモートコマンドを返す
- エージェントが応答を解析する
- TCP 接続が閉じられる
- エージェントが定期的なデータ収集を開始し、リモートコマンドを実行する(Zabbix agent 7.0 以降でサポート)
active check を使用すると、Zabbix server trapper ポートにアクセスできる第三者が、機密性のある設定データを取得できる可能性があることに注意してください。これは、誰でもアクティブエージェントを装ってアイテム設定データを要求できるためです。
encryption オプションを使用しない限り、認証は行われません。
収集済みデータの送信
エージェント送信
エージェントのデータ要求には、収集されたアイテム値と、実行されたリモートコマンドの値(ある場合)が含まれます。
{
"request": "agent data",
"data": [
{
"id": 1,
"itemid": 5678,
"value": "7.0.0",
"clock": 1712830783,
"ns": 76808644
},
{
"id": 2,
"itemid": 1234,
"value": "69672",
"clock": 1712830783,
"ns": 77053975
}
],
"commands": [
{
"id": 1324,
"value": "16G"
}
],
"session": "8495cd52070e6ca52b371f29c8574165",
"host": "Zabbix server",
"version": "7.4.0",
"variant": 2
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| request | string | yes | agent data |
|
| data | array of objects | yes | アイテム値。 | |
| id | number | yes | 値の識別子(ネットワーク問題が発生した場合に重複値を確認するために使用される増分カウンター)。 | |
| itemid | number | yes | アイテムの識別子。 | |
| value | string | no | アイテム値。 | |
| lastlogsize | number | no | アイテムの lastlogsize。 | |
| mtime | number | no | アイテムの mtime。 | |
| state | number | no | アイテムの state。 | |
| source | string | no | 値のイベントログソース。 | |
| eventid | number | no | 値のイベントログ eventid。 | |
| severity | number | no | 値のイベントログ severity。 | |
| timestamp | number | no | 値のイベントログ timestamp。 | |
| clock | number | yes | 値のタイムスタンプ(Epoch からの秒数)。 | |
| ns | number | yes | 値のタイムスタンプのナノ秒。 | |
| commands | array of objects | no | リモートコマンドの実行結果。アクティブエージェントでのリモートコマンド実行は Zabbix agent 7.0 以降でサポートされます。古いアクティブエージェントは、アクティブチェックのサーバー応答に含まれるリモートコマンドを無視します。 | |
| id | number | no | リモートコマンドの識別子。 | |
| value | string | no | 実行が成功した場合のリモートコマンドの実行結果。 | |
| error | string | no | 実行が失敗した場合のリモートコマンド実行エラーメッセージ。 | |
| session | string | yes | エージェントの起動時に毎回生成される一意のセッション識別子。 | |
| host | string | yes | ホスト名。 | |
| version | string | yes | エージェントのバージョン番号。 | |
| variant | number | yes | エージェントの種類(1 - Zabbix agent、2 - Zabbix agent 2)。 | |
各値には仮想 ID が割り当てられます。値 ID は単純な昇順のカウンターで、1つのデータセッション内で一意です(セッショントークンで識別されます)。この ID は、接続品質が悪い環境で送信される可能性のある重複値を破棄するために使用されます。
サーバー応答
エージェントデータ応答は、エージェントデータ要求を処理した後にサーバーからエージェントへ返送されます。
{
"response": "success",
"info": "processed: 2; failed: 0; total: 2; seconds spent: 0.003534"
}
| Field | Type | Mandatory | Value |
|---|---|---|---|
| response | string | yes | success | failed |
| info | string | yes | アイテム処理結果。 |
一部の値の送信がサーバー側で失敗した場合(たとえば、ホストまたはアイテムが無効化または削除されている場合)、エージェントはそれらの値の再送信を行いません。
例:
- エージェントが TCP 接続を開く
- エージェントが値の一覧を送信する
- サーバーがデータを処理し、ステータスを返す
- TCP 接続が閉じられる
エラーメッセージはサーバー側で 2048 文字に切り詰められます。
ハートビートメッセージ
エージェントが送信
ハートビートメッセージは、アクティブなエージェントから Zabbix サーバー/プロキシへ、HeartbeatFrequency 秒ごとに送信されます(Zabbix agent/agent 2 の設定ファイルで構成)。
これは、アクティブチェックの可用性を監視するために使用されます。
{
"request": "active check heartbeat",
"host": "Zabbix server",
"heartbeat_freq": 60,
"version": "7.4.0",
"variant": 2
}
| Field | Type | Mandatory | Value |
|---|---|---|---|
| request | string | yes | active check heartbeat |
| host | string | yes | ホスト名。 |
| heartbeat_freq | number | yes | エージェントのハートビート頻度(HeartbeatFrequency 設定パラメータ)。 |
| version | string | yes | エージェントのバージョン番号。 |
| variant | number | yes | エージェントの種類(1 - Zabbix agent、2 - Zabbix agent 2)。 |
リダイレクト応答
ホストが再割り当てされた場合、サーバーはエージェントに対して、ハートビート(および以降のアクティブチェック)を別のプロキシまたはサーバーインスタンスへリダイレクトするよう指示できます。
{
"response": "failed",
"redirect": {
"revision": 2,
"address": "192.0.2.1:10055"
}
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| response | string | yes | success | failed |
|
| redirect | object | yes | リダイレクト指示。 | |
| revision | number | yes | 設定リビジョン識別子。 | |
| address | string | yes | リダイレクト先のサーバー/プロキシアドレス。 | |
古い XML プロトコル
Zabbixは、 Base64にエンコードされたXMLのデータを16MBまで取得しますが、デコードされる値は1つが64KB以下でなければなりません。そうでないと、デコード中にそれが64KBに切り捨てられます。