ZABBIX自動検出ポートモニタ
6203 ワード
リファレンス http://ywzhou.blog.51cto.com/2785388/1580160
1クライアント新規スクリプト
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
chmod +x discovertcpport.sh ##実行権限の追加
スクリプトの説明:
netstatコマンドを使用してポート番号を出力します.-tnlp=Tcpプロトコル+別名を表示しない+listen状態+プログラム名を表示します.$1~$9は出力のいくつか目のパラメータを表す.awk {'print $4'}は出力の4番目のパラメータ(例えば0.0.0.0:80)を表す.awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}は、コロンの後ろを切り取る値を表し、0~9の数字しかありません.|sort|uniqはソートとデウェイトを表す.
2、クライアントはdiscoveryのkeyを増加する
1
2
3、zabbixを再起動するAgentdサービス
/etc/init.d/zabbix_agentd restart
4サービス・エンド・テスト
1
2
3
4
5
6
7
8
これらを返すと正常です
5.Linuxテンプレートにポート自動発見規則を作成する
自動検出ルール名とKEYを設定する:
Itemプロトタイプの作成
トリガプロトタイプを作成するには:
イメージプロトタイプの作成
6成功したかどうかを確認し、monitoring-latest dataでポート生成があるかどうかを確認します.
7画像が生成されたかどうかを確認する
これで、モニタポートが完了しました.
8の間に発生した問題
1 スクリプトを実行するときのヒント Not all processes could be identified, non-owned process info
will not be shown,you would have to be root to see it all.)権限がないという意味ですが、
2自動検出ルールの追加後、ヒント Value should be a JSON objectこのエラー
解決策はvim /etc/sudoers
1
2
そして上のスクリプトにsudo netstat-tnlp|egrep-i"$1"|awk{'print$4'}|awk-F':'{if($NF~/^[0-9]*$/)print$NF}'|sort|uniq
1クライアント新規スクリプト
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#!/bin/bash
portarray=(`sudo netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort|uniq`)
length=${#portarray[@]}
printf "{
"
printf '\t'"\"data\":["
for ((i=0;i
do
printf '
\t\t{'
printf "\"{#TCP_PORT}\":\"${portarray[$i]}\"}"
if [ $i -lt $[$length-1] ];then
printf ','
fi
done
printf "
\t]
"
printf "}
"
chmod +x discovertcpport.sh ##実行権限の追加
スクリプトの説明:
netstatコマンドを使用してポート番号を出力します.-tnlp=Tcpプロトコル+別名を表示しない+listen状態+プログラム名を表示します.$1~$9は出力のいくつか目のパラメータを表す.awk {'print $4'}は出力の4番目のパラメータ(例えば0.0.0.0:80)を表す.awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}は、コロンの後ろを切り取る値を表し、0~9の数字しかありません.|sort|uniqはソートとデウェイトを表す.
2、クライアントはdiscoveryのkeyを増加する
1
2
UnsafeUserParameters=1
UserParameter=tcpportlisten,/usr/local/zabbix_agent/sbin/discovertcpport.sh "$1"
3、zabbixを再起動するAgentdサービス
/etc/init.d/zabbix_agentd restart
4サービス・エンド・テスト
1
2
3
4
5
6
7
8
/usr/local/zabbix/bin/zabbix_get -s 192.168.127.134 -k tcpportlisten
{
"data":[
{"{#TCP_PORT}":"10050"},
{"{#TCP_PORT}":"22"},
{"{#TCP_PORT}":"80"}
]
}
これらを返すと正常です
5.Linuxテンプレートにポート自動発見規則を作成する

自動検出ルール名とKEYを設定する:


Itemプロトタイプの作成

トリガプロトタイプを作成するには:


イメージプロトタイプの作成

6成功したかどうかを確認し、monitoring-latest dataでポート生成があるかどうかを確認します.

7画像が生成されたかどうかを確認する

これで、モニタポートが完了しました.
8の間に発生した問題
1 スクリプトを実行するときのヒント Not all processes could be identified, non-owned process info
will not be shown,you would have to be root to see it all.)権限がないという意味ですが、
2自動検出ルールの追加後、ヒント Value should be a JSON objectこのエラー
解決策はvim /etc/sudoers
1
2
#Defaults requiretty
zabbix ALL=(ALL) NOPASSWD: ALL
そして上のスクリプトにsudo netstat-tnlp|egrep-i"$1"|awk{'print$4'}|awk-F':'{if($NF~/^[0-9]*$/)print$NF}'|sort|uniq