はじめに:
1、オンラインビジネスの監視を行うために、何百haproxyサービスの数十を使用して、これらのサービスのために(haproxyポートモニタのTCPコネクション、haproxyサービス監視を対応含みます)。
2、ここでは複雑すぎる「UserParameter」道の内部zabbix_agentd.confでの一般的な構成は、(、データを収集するために集約されたデータを)テーブルを構築するために使用する方法。
3は、データが第三者を通じて、データ処理のためのスクリプトを作るための治療を受けるために、結果を監視し、表にまとめられています。
(haproxy情報サービスを収集)データテーブルを作成します。
zabbix_DBでテーブルを作成します。t_3party_serverを
create table t_3party_server(
app varchar(64) NOT NULL,
server varchar(64) NOT NULL,
division varchar(64) NOT NULL,
node varchar(64) NOT NULL,
port varchar(64) NOT NULL,
remark int(10) unsigned NOT NULL,
PRIMARY KEY (app,server,division,node,port)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
注释:
app #这里写的是项目名称(MOBA项目)
server #服务名称(haproxy服务)
division #由于起了多个haproxy实例,名称也不一样,所以这里做了区分
node #haproxy服务IP地址
port #haproxy服务端口,多个实例端口不同
remark #备注作用(由于线上某些haproxy服务安装路径不一致,所以此处用来区分路径,也可以区分其他)
PRIMARY KEY (app,server,division,node,port) #添加主键
テーブル構造の表示を終了した後
そして、データテーブル内のデータを挿入します。
insert into t_3party_server(app,server,division,node,port,remark) values('MM','haproxy','haproxy-login','192.168.32.128','30000','0');
ファイナルテーブル結果
生成されたデータテーブルの監視を行います
監視スクリプト:zabbix_server下に置かれた "/ INSTALL_PATH / zabbix_server /共有/ ZABBIX / externalscripts"
<?php
if ($_SERVER["argc"] != 2) {
echo "Usage: " . $_SERVER["argv"][0] . " host\n";
return;
}
$host = $_SERVER["argv"][1];
$mysqlconn = new mysqli("localhost", "root", "123", "zabbix", 3306);
if (mysqli_connect_errno()) {
echo "fail to connect mysql: " . mysqli_connect_error() . "\n";
return;
}
$result = $mysqlconn->query("SELECT * FROM t_3party_server WHERE node=\"" . $mysqlconn->real_escape_string($host) . "\"");
$hostvalue = array(
"data" => array()
);
while ($row = $result->fetch_assoc()) {
$app = $row["app"];
$server = $row["server"];
$division = $row["division"];
$node = $row["node"];
$port = $row["port"];
$remark = $row["remark"];
if ($remark == "/usr/local")
{
$hostvalue["data"][] = array(
"{#APP}" => $app,
"{#SERVER}" => $server,
"{#DIVISION}" => $division,
"{#PORT}" => $port,
"{#PATH}" => "/usr/local/" . $division . "/sbin",
);
continue;
}
$server = substr($server, 0, 15);
$hostvalue["data"][] = array(
"{#APP}" => $app,
"{#SERVER}" => $server,
"{#DIVISION}" => $division,
"{#PORT}" => $port,
"{#PATH}" => "/data/app/" . $division . "/sbin",
#"{#MFW_PATH}" => "/data/app/" . $division . "/" . ($division ? $division . "/" : "") . $server,
);
}
echo json_encode($hostvalue);
echo "\n";
スクリプトの生成データ:
[root@localhost externalscripts]# ./haproxy_discovery.php 192.168.32.128
{"data":[{"{#APP}":"MM","{#SERVER}":"haproxy","{#DIVISION}":"haproxy-login","{#PORT}":"30000","{#PATH}":"\/data\/app\/haproxy-login\/sbin"}]}
JSON形式の変換:
{
"data":[
{
"{#APP}":"MM",
"{#SERVER}":"haproxy",
"{#DIVISION}":"haproxy-login",
"{#PORT}":"30000",
"{#PATH}":"/data/app/haproxy-login/sbin"
}
]
}
マシン上で構成Haproxyサービス
1、構成:zabbix_agentd.conf
#用来监控TCP连接数
UserParameter=haproxy.tcp.[*],/usr/sbin/ss -ant sport eq :"$1" | awk 'NR>1{++s[$$1]} END {for(k in s){print k,s[k]}}' |grep -w "ESTAB" |awk '{print $$2}'
配置完成后重启zabbix_agentd
ZABBIXで監視を追加
>自動検出ルール - テンプレートの作成
マクロ変数を定義した:マクロ値が導出されるJSON
Item1:检查haproxy进程是否存在
Key:proc.num["{#SERVER}",,,"{#PATH}"]
Trigger1:对应Item1
{customize template:proc.num["{#SERVER}",,,"{#PATH}"].last()}<1
Item2:检查haproxy端口对应的TCP连接数
Key:haproxy.tcp.[{#PORT}]
Trigger2:对应Item2
{Template moba server:haproxy.tcp.[{#PORT}].last()}>40000
haproxy新しいサービスは、監視プロセスに追加された後、次のようです
1、在zabbixDB上的t_3party_server表里添加数据:
INSERT INTO `zabbix`.`t_3party_server` (`app`, `server`, `division`, `node`, `port`, `remark`) VALUES ('MOBA', 'haproxy', 'haproxy', '10.111.152.15', '30032', '0');
2、在机器上添加配置参数:
vim /data/app/zabbix_agent/etc/zabbix_agentd.conf
#Haproxy
UserParameter=haproxy.tcp.[*],/usr/sbin/ss -ant sport eq :"$1" | awk 'NR>1{++s[$$1]} END {for(k in s){print k,s[k]}}' |grep -w "ESTAB" |awk '{print $$2}'
3、配置完毕后重启 zabbix_agentd
pkill zabbix_agentd
/data/app/zabbix_agent/sbin/zabbix_agentd
4、到zabbix上监控haproxy服务是否被监控