环境centos6.8
zabbix版本3.2.4
需求:
要远程监控一台服务器A,但只能通过远程服务器连接本地服务器B,但B不能主动连A(因为A没有固定公网ip)
使用了zabbix_agent的active模式,但这种模式不能使用ping方式确定agent是否存活,使用触发规则nodata测试
A服务器网络不稳定,很容易误触发规则(若有大神评论区教教我,是不是我哪里设置错了)
最后
究其原因,主要是使用触发器失败,改用了这种方法,当做心跳线使用
zabbix官方文档:https://www.zabbix.com/documentation/3.2/manual/config/triggers/expression
实施例8
最近3分钟内没有心跳
使用函数nodata():
{zabbix.zabbix.com:tick.nodata(3m)}=1
'tick'必须有“Zabbix trapper”类型。为了使此触发器工作,必须定义项目'tick'。主机应使用zabbix_sender定期发送此参数的数据。如果在180秒内没有收到数据,则触发值成为问题。
一、zabbix-sender介绍
zabbix_sender是一个命令行工具,可以用来发送Zabbix服务器处理性能数据。该工具通常用于长时间运行的用户脚本,用于定期发送可用性和性能数据。
zabbix获取key值有超时时间,如果自定义的key脚本一般需要执行很长时间,这根本没法去做监控,那怎么办呢?
使用zabbix监控类型zabbix trapper,需要配合zabbix_sender给它传递数据。关于trapper的用法,我们来弄个实例。
执行超长时间脚本,如:脚本去几十台服务器拉去数据,每个日志都上G,然后日志整合在一起,统计出返回值。这种脚本比如超时,所以我们必须改成让客户端提交数据的方式。
这里是zabbix-sender设计的初衷,被我这样用也是无奈!!
二、zabbix_sender命令详解
[root@localhost]# ./zabbix_sender
usage: zabbix_sender [-Vhv] {[-zpsI] -ko | [-zpI] -T -i <file> -r} [-c <file>]
参数说明:
-c --config <file> 配置文件绝对路径
-z --zabbix-server <server> zabbix server的IP地址
-p --port <server port> zabbix server端口.默认10051
-s --host <hostname> 主机名,zabbix里面配置的主机名(不是服务器的hostname),不能使用ip地址
-I --source-address <IP address> 源IP
-k --key <key> 监控项的key
-o --value <key value> key值
-i --input-file <input file> 从文件里面读取hostname、key、value 一行为一条数据,使用空格作为分隔符,如果主机名带空格,那么请使用双引号包起来
-T --with-timestamps 一行一条数据,空格作为分隔符: <hostname> <key> <timestamp> <value>,配合 --input-file option,timestamp为unix时间戳
-r --real-time 将数据实时提交给服务器
-v --verbose 详细模式, -vv 更详细
三、zabbix_sender应用实例
zabbix获取数据有超时时间,如果一些数据需要执行比较长的时间才能获取的话,那么zabbix会出现异常,考虑到这种情况,zabbix增加了Trapper功能,客户端自己提交数据给zabbix,这个通道便是trapper.
使用trapper的步骤如下:
- 在zabbix中配置trapper监控项
- 传递数据到zabbix中
1、进入zabbix web界面选择一台主机(或模板)--items--Create item 定义一个key用来接受客户端的sender,如下图:
(1)我采用的是模板添加,方便以后统一添加
(2)也可以采用hosts添加items
这里的几幅图看不清楚,博客园貌似图片有限制加上小图
###############################
之前百度了许多关于sender的内容,但都是2.2或2.4版本,比较老,3.2.4还是有些不一样的
到这里创建items成功
(这里的key是自定义的,在使用sender时需要用到,大概是秘钥配对的感觉,不知道对不对)
2、回到客户端使用以下命令sender数据
zabbix_sender -s "126" -z 192.168.1.104 -p 10050 -k "trap" -o 1
这里
- -s后面跟的参数是agent端的hostname
- -z后面跟的参数是server端的ip
- -p后面跟的参数是server端的端口(不写默认为10051)
- -k就是刚刚建items时自定义的key值-o是你想发送的数据(要是选择的txt接收模式,也可以为字符)
[root@localhost.localdomain 五 4月 28 14:52:32 ~]# zabbix_sender -s "126" -z 192.168.1.104 -k "trap" -o 1
info from server: "processed: 1; failed: 0; total: 1; seconds spent: 0.000050"
sent: 1; skipped: 0; total: 1
这里会提示是否正确发送,若failed是1,表示有一个失败,即发送消息失败,这里s跟k参数最好都加上引号,之前就是这个原因一直失败
3、再回到zabbix web端选择前面的主机--点击Latest data 如下图:
这时看见在这里是没有数据的,这里就跟2.4版本不一样了
我只用数字1表示有信号
这里就告一段落了
4、添加触发器
这里的触发规则,具体的我也不会,我只是套用了模板,使用trap这个key键,语句是nodata,然后再设置对应的参数,这里具体的要看官方文档了
到这里就设置好了server端
5、客户端添加脚本
再到agent端
zabbix_sender -s "126" -z 192.168.1.104 -k "trap" -o 1
添加执行权限
chmod +x zabbix_sender.sh
添加定时计划
* * * * * /usr/local/src/zabbix_sender.sh
然后就能运行了
这样就算一个完整的报警了,虽然很烂
"世界上只有一种真正的英雄主义,就是认清了生活的真相后,还依然执着地热爱它。" ——罗曼·罗兰