Zabbix(五):高级应用-web方案、被动监控、基于snmp协议被动监控、proxy配置测试实例

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

1.web方案

web scenario:web监控方案,web场景;

web scenarios指的是监控指定的web站点的资源下载及页面响应时间等数据指标;


(1)创建web监控需要先定义一个web scenario(方案):

一个web方案包括一个或多个HTTP请求或步骤(steps)

每次监控都是按照预先定义的步骤的顺序执行;

(2)通过web监控方案可以获取到下列信息:

整个web方案中所有步骤的速度和响应时间,以及平均下载速度和平均响应时间;

失败的步骤号

失败的报错信息

(3)在设置web方案中的具体步骤时,可以按需调用此步骤的下载速度和响应时间,以及响应状态码;

(4)Zabbix可以检测获取到HTML页面中是否包含预设的字符串信息,也可以实现模拟浏览器完成登录,身份验证和页面点击的功能;

(5)在创建完成一个步骤以后,Zabbix会自动在已经选择好的application中添加若干个items,这些items可以用于创建触发器及定义报警条件;


基于之前创建的nginxweb创建web,点击Hosts里面nginxweb后面的web,点击Create web scenario

1.png


在Steps添加相关内容

2.png


创建完成后,查看latest data,多了六项内容

3.png




2.Zabbix的主动/被动检测

被动检测:相对于agent而言,agent接口,Zabbix server向Zabbix agent请求获取配置的各items相关的数据,agent负责接收请求、获取数据并响应给Zabbix server

主动检测:相对于agent而言,agent(active)接口,Zabbix agent向Zabbix server请求与自己相关的items的配置,主动地将监控数据发送给Zabbix server;


配置主动检测,在agent端需要的基本配置:

ServerActive=Zabbix_server,Zabbix_proxy

Hostname=Local_hostname


在agent端需要的基本配置

##### Active checks related,在该配置段中配置一下内容


ServerActive=172.16.1.2

Hostname=zrs2.zrs.com


还要在server端配置一下内容

[root@zrs1 ~]# vim /etc/hosts

172.16.1.4  zrs2.zrs.com zrs2


删除之前的host,创建一个新的host

4.png


在这个host上面创建item,preprocessing中改为Change per second

5.png


查看,因为有之前创建的的模版,所以直接加进当前host中,为5个item和2个application,可以看到已经监控成功。

6.png


3.基于snmp协议被动监控


什么是SNMP

SNMP:“简单网络管理协议”,用于网络管理的协议。SNMP用于网络设备的管理。SNMP的工作方式:管理员需要向设备获取数据,所以SNMP提供了“读”操作;管理员需要向设备执行设置操作,所以SNMP提供了“写”操作;设备需要在重要状况改变的时候,向管理员通报事件的发生,所以SNMP提供了“Trap”操作。


监听端口

161/udp

162/udp


CentOS 6/7:支持SNMP协议的方法:

net-snmp,net-snmp-utils


配置文件:

/etc/snmp/snmpd.conf


启动服务:

systemctl start snmpd.service


测试工具:

snmpget -v 2c -c public HOST OID

snmpwalk -v 2c -c public HOST OID



在被管理的主机上,关闭zabbix-agent服务

[root@zrs2 ~]# systemctl stop zabbix-agent.service


在监控主机和被监控主机上都下载snmp服务

yum -y install net-snmp net-snmp-utils


在被监控的主机上启动服务

[root@zrs2 ~]# systemctl start snmpd.service


在监控主机上测试

[root@zrs1 ~]# snmpget -v 2c -c public 172.16.1.4 system.sysDescr.0

SNMPv2-MIB::sysDescr.0 = STRING: Linux zrs2.zrs.com 3.10.0-327.el7.x86_64 #1 SMP Thu Nov 19 22:10:57 UTC 2015 x86_64


删除之前的host,创建新的基于snmp的host,还用原来的name

7.png


创建item,监控网络流量,snmp可以任意写一个key,snmp监控在OID上面,preprocessing中改为Change per second

8.png



4.Zabbix Proxy


分布式监控的模型之一;


两种类型:

server-node-agent

server-proxy-agent(zabbix 3.0+)


安装和配置Zabbix proxy:

完成代理功能:

zabbix-proxy-mysql zabbix-get

实现将采集的数据传回给server:

zabbix-sender

想要监控proxy主机:

zabbix-agent



打开一台新的虚拟机172.16.1.5,安装zabbix-proxy-mysql zabbix-get zabbix-sender zabbix-agent作为反代主机

[root@zrs4 ~]# hostname

zrs4.zrs.com


配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
[root@zrs4 ~] # egrep -v '^$|#' /etc/zabbix/zabbix_proxy.conf 
ProxyMode=0
Server=172.16.1.2
Hostname=zrs4.zrs.com
LogFile= /var/log/zabbix/zabbix_proxy .log
LogFileSize=0
PidFile= /var/run/zabbix/zabbix_proxy .pid
SocketDir= /var/run/zabbix
DBHost=172.16.1.5
DBName=zbxdb
DBUser=zabbixuser
DBPassword=zabbixpass
ConfigFrequency=60
DataSenderFrequency=5
StartPollers=5
StartPollersUnreachable=1
StartTrappers=5
StartPingers=1
StartDiscoverers=1
StartHTTPPollers=1
SNMPTrapperFile= /var/log/snmptrap/snmptrap .log
Timeout=4
ExternalScripts= /usr/lib/zabbix/externalscripts
LogSlowQueries=3000



创建数据库

1
2
3
4
5
[root@zrs4 ~] # systemctl start mariadb
[root@zrs4 ~] # mysql
MariaDB [(none)]> create database zbxdb charset  'utf8' ;
MariaDB [(none)]> use zbxdb;
MariaDB [(none)]> grant all on zbxdb.* to zabbixuser@ '172.16.%.%'  identified by  'zabbixpass' ;

导入数据库

1
2
3
4
5
6
[root@zrs4 ~] # cp /usr/share/doc/zabbix-proxy-mysql-3.4.4/schema.sql.gz /root
[root@zrs4 ~] # ls
anaconda-ks.cfg  initial-setup-ks.cfg  schema.sql.gz
[root@zrs4 ~] # gunzip schema.sql.gz 
[root@zrs4 ~] # mysql -uzabbixuser -h172.16.1.5 -p zbxdb < schema.sql 
Enter password:


启动服务

systemctl start zabbix-proxy.service


在Administration的Proxies中创建反代

9.png


打开一台新的虚拟机172.16.1.10,安装 zabbix-sender zabbix-agent,作为反代服务器的后端

[root@zrs5 ~]# hostname

zrs5.zrs.com


配置文件

1
2
3
4
5
6
7
8
9
10
11
[root@zrs5 ~] # egrep -v '^$|#' /etc/zabbix/zabbix_agentd.conf 
PidFile= /var/run/zabbix/zabbix_agentd .pid
LogFile= /var/log/zabbix/zabbix_agentd .log
LogFileSize=0
EnableRemoteCommands=1
Server=172.16.1.5
ListenPort=10050
  StartAgents=3
ServerActive=12.16.1.5
Hostname=zrs5.zrs.com
Include= /etc/zabbix/zabbix_agentd .d/

创建发现规则

10.png


再创建动作,就可以通过反代自动添加主机了。

11.png

12.png


查看Hosts,发现这个主机已经成功添加进来了,给监控到的这个主机创建一个item监控项,preprocessing中改为Change per second

13.png


然后查看Hosts,这个主机的绿灯也亮了。

14.png


查看这个主机的Latest data,正常监控了。

15.png




本文转自 Runs_ 51CTO博客,原文链接:http://blog.51cto.com/12667170/2045533,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
1月前
|
监控 应用服务中间件 nginx
基于Zabbix的SLA监控体系构建与实践
本文由Zabbix社区专家褚凤彬分享,详解SLA在Zabbix中的应用。通过Trigger与Service联动,构建Web应用的多层级监控体系,并介绍SLA计算规则、维护期处理及升级注意事项,助力企业精准掌控服务可用性。
331 36
|
2月前
|
消息中间件 运维 应用服务中间件
“企业微信iPad协议”凌晨断链:当最后一台测试机决定集体沉默
凌晨1:12,三连报警突响:“实例心跳超时”“消息队列堆积”“老板提刀赶来”。问题源于企业微信iPad协议迁移私有化后,因新旧CA根证书不兼容,触发TLS握手失败,导致全量会话中断。苹果严苛的证书校验机制将请求判定为中间人攻击,直接断连。排查抓包定位:客户端内置证书Pin仅认旧根。解决方案简单却关键:F5重导旧根证书,Nginx配置`ssl_trusted_certificate`指向旧链并reload。2:58,系统恢复,演练数据零丢失。教训深刻:文档未提CA白名单,真实逻辑藏于客户端二进制。部署前务必比对证书指纹,否则警报先于用户消息抵达。
177 1
|
3月前
|
搜索推荐 Devops 测试技术
避免无效回归!基于MCP协议的精准测试影响分析实践
本文揭示传统测试的"孤岛困境",提出MCP(Model Context Protocol)测试新范式,通过模型抽象业务、上下文感知环境和协议规范协作,实现从机械执行到智能测试的转变。剖析MCP如何颠覆测试流程,展示典型应用场景,并提供团队落地实践路径,助力测试工程师把握质量效率革命的新机遇。
|
5月前
|
弹性计算 JavaScript Ubuntu
WebSocket协议相关的测试命令工具使用简介
本文介绍了针对WebSocket的测试工具wscat和websocat的基本使用方法,以及通过curl命令测试HTTP/HTTPS协议的方式。对于WebSocket,直接使用curl测试较为复杂,推荐使用wscat或websocat。文中详细说明了这两种工具的安装步骤、常用参数及连接示例,例如在ECS上开启8080端口监听并进行消息收发测试。此外,还提供了curl命令的手动设置头部信息以模拟WebSocket握手的示例,但指出curl仅能作为客户端测试工具,无法模拟服务器。
1301 4
|
5月前
|
自然语言处理 算法 数据可视化
文本聚类效果差?5种主流算法性能测试帮你找到最佳方案
本文探讨了自然语言处理中句子嵌入的聚类技术,使用Billingsmoore数据集(925个英语句子)进行实验。通过生成句子嵌入向量并可视化分析,对比了K-Means、DBSCAN、HDBSCAN、凝聚型层次聚类和谱聚类等算法的表现。结果表明,K-Means适合已知聚类数量的场景,DBSCAN和HDBSCAN适用于未知聚类数量且存在异常值的情况,而谱聚类在句子嵌入领域表现不佳。最终建议根据数据特征和计算资源选择合适的算法以实现高质量聚类。
298 0
文本聚类效果差?5种主流算法性能测试帮你找到最佳方案
|
7月前
|
运维 监控 安全
【案例分享】中国通号卡斯柯公司:ZABBIX如何破解轨道交通监控难题
本文根据2023上海峰会上朱林贤的演讲整理,聚焦中国通号卡斯柯公司如何借助Zabbix实现轨道交通信号系统的智能化管理。作为中外合资企业,卡斯柯通过统一平台整合设备监控,大幅降低成本并提升灵活性,成功应用于国内外项目。文章探讨了传统监控系统的痛点、研发维护经验及国产化与开源技术挑战,为行业转型提供了宝贵启示。未来,开放协作将是推动轨道交通智能化发展的关键。
378 8
|
9月前
|
监控 Linux PHP
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
316 20
|
10月前
|
缓存 网络协议
Jmeter如何对UDP协议进行测试?
`jmeter-plugins`是JMeter的插件管理器,用于管理和组织所有插件。访问[官网](https://jmeter-plugins.org/install/Install/)下载并放置于`lib/ext`目录下,重启JMeter后可在“选项”中看到插件管理器。
368 1
Jmeter如何对UDP协议进行测试?
|
9月前
|
存储 缓存 监控
|
9月前
|
监控 关系型数据库 MySQL
【01】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-硬件设备实时监控系统运营版发布-本产品基于企业级开源项目Zabbix深度二开-分步骤实现预计10篇合集-自营版
【01】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-硬件设备实时监控系统运营版发布-本产品基于企业级开源项目Zabbix深度二开-分步骤实现预计10篇合集-自营版
285 0

推荐镜像

更多