目录

  • 监控系统
  • 一、zabbix 简介
  • 1 Zabbix概述
  • 2.zabbix 监控原理:
  • 二、安装 zabbix 5.0服务器
  • 1.部署 zabbix 服务端
  • 2.部署 zabbix 客户端
  • 3.自定义监控内容
  • 1.创建模板
  • 2.创建应用集
  • 3.创建监控项
  • 4.创建触发器
  • 5.创建图形
  • 6.将主机与模板关联起来
  • 7.设置邮件报警
  • 8.测试邮件报警
  • 4.zabbix 自动发现与自动注册
  • 自动发现
  • zabbix 自动注册

监控系统

监控应用服务,对服务器、虚拟机、应用服务的业务状态和相关的性能进行监控,例如服务器上的CPU性能内存、性能、磁盘性能硬件监控,还有软件监控:web应用、数据库应用,对应用软件进行性能监控,web应用的并发量、数据库的连接数、查询时间做监控

传统运维:zabbix(底层用的是关系型数据库,效率速度比较慢)、 Nagios

云环境:Prometheus (用的是时间序列数据库,对监控数据非常友好的,用go开发,对高并发有很好的适应能力)

作为一个运维,需要会使用监控系统查看服务器状态以及网站流量指标,利用监控系统的数据去了解上线发布的结果,和网站的健康状态。

利用一个优秀的监控软件,我们可以:

  • 通过一个友好的界面进行浏览整个网站所有的服务器状态
  • 可以在 Web 前端方便的查看监控数据
  • 可以回溯寻找事故发生时系统的问题和报警情况

一、zabbix 简介

1 Zabbix概述

  • zabbix 是一个基于 Web 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
  • zabbix 能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
  • zabbix 由 2 部分构成,zabbix server 与可选组件 zabbix agent。通过 C/S 模式采集数据,通过 B/S 模式在 Web 端展示和配置。
  • zabbix server 可以通过 SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能, 它可以运行在 Linux 等平台上。
  • zabbix agent 需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU 等信息的收集。

2.zabbix 监控原理:

zabbix agent安装在被监控的主机上,zabbix agent负责定期收集客户端本地各项数据,并发送至 zabbix server 端,zabbix server 收到数据后,将数据存储到数据库中,用户基于 Zabbix WEB 可以看到数据在前端展现图像。当 zabbix 监控某个具体的项目, 该项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、install 等)。

zabbix 监控部署在系统中,包含常见的五个程序: zabbix_server、zabbix_agent、zabbix_proxy、zabbix_get、zabbix_sender 等。

  • zabbix server:zabbix 服务端守护进程,其中 zabbix_agent、zabbix_get、zabbix_sender、zabbix_proxy 的数据最终都提交给 zabbix server;
  • zabbix agent:客户端守护进程,负责收集客户端数据,例如:收集 CPU 负载、内存、硬盘使用情况等;
  • zabbix proxy:zabbix 分布式代理守护进程,通常大于 500 台主机,需要进行分布式监控架构部署;
  • zabbix get:zabbix 数据接收工具,单独使用的命令,通常在 server 或者 proxy 端执行获取远程客户端信息的命令;
  • zabbix sender:zabbix 数据发送工具,用户发送数据给 server 或 proxy 端,通常用户耗时比较长的检查。

二、安装 zabbix 5.0服务器

1.部署 zabbix 服务端

zabbix-server 内存至少 2G,推荐 4G;

#准备工作
systemctl disable --now firewalld
setenforce 0
hostnamectl set-hostname zbx-server
#获取 zabbix 的下载源
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
 cd /etc/yum.repos.d/
 ls
#bak  CentOS-Base.repo  zabbix.repo
#更换 zabbix.repo 为阿里源(用国内源快)
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
yum clean all && yum makecache

yum install -y zabbix-server-mysql zabbix-agent
#安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。软件包会安装在 /etc/opt/rh 目录下。

yum install -y centos-release-scl 
#修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
vim zabbix.repo
......
[zabbix-frontend]
......
enabled=1          #开启安装源
......
#web前段的工作支持mysql 支持apache
yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl

#安装 zabbix 所需的数据库
yum install -y mariadb-server mariadb
#启动服务并设置开机自启
systemctl start mariadb.service
systemctl enable mariadb.service
netstat -ntap | grep 3306

#初始化数据库,并设置密码,如 abc123
mysql_secure_installation
#添加数据库用户,以及 zabbix 所需的数据库信息
mysql -u root -pabc123

#创建一个库,并且设置默认字符集utf8,让zabbix用户可以操作zabbix表,用户密码设置zabbix
CREATE DATABASE zabbix character set utf8 collate utf8_bin;
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
flush privileges;

#导入数据库信息
rpm -ql zabbix-server-mysql 		#查询 sql 文件的位置
cd /usr/share/doc/zabbix-server-mysql-5.0.24/
zcat create.sql.gz | mysql -uroot -pabc123 zabbix

#修改 zabbix server 配置文件,修改数据库的密码(服务端)
vim /etc/zabbix/zabbix_server.conf 

124  DBPassword=zabbix #124行,指定 zabbix 数据库的密码

#修改 zabbix 的 php 配置文件
vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
......
php_value[date.timezone] = Asia/Shanghai		#24行,取消注释,修改时区为上海

#启动 zabbix 相关服务
systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm

#浏览器访问:http://192.168.239.20/zabbix
#点击下一步,设置数据库的密码 zabbix
#安装完成后,默认的登录账号和密码为:Admin/zabbix
#设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 更新。

#解决 zabbix-server Web页面中文乱码问题
yum install -y wqy-microhei-fonts

\cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏


zabbix 监控项无法获取值告警 zabbix监控was_客户端_02


zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_03


zabbix 监控项无法获取值告警 zabbix监控was_服务端_04


zabbix 监控项无法获取值告警 zabbix监控was_客户端_05

2.部署 zabbix 客户端

zabbix 5.0 版本采用 golang 语言开发的新版本客户端 agent2 。
zabbix 服务端 zabbix_server 默认使用 10051 端口,客户端 zabbix_agent2 默认使用 10050 端口。

#准备工作
systemctl disable --now firewalld
setenforce 0
hostnamectl set-hostname zbx-agent01

#服务端和客户端都配置时间同步(阿里源时钟源)建议做个crontab周期同步
yum install -y ntpdate
ntpdate -u ntp.aliyun.com

#客户端配置时区,与服务器保持一致
mv /etc/localtime{,.bak}
ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

date

#设置 zabbix 的下载源,安装 zabbix-agent2
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm 

cd /etc/yum.repos.d
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo

yum install -y zabbix-agent2

#修改 agent2 配置文件
vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.239.20			#80行,指定 zabbix 服务端的 IP 地址
ServerActive=192.168.239.20		#120行,指定 zabbix 服务端的 IP 地址
Hostname=zbx-agent01			#131行,指定当前 zabbix 客户端的主机名

#启动 zabbix-agent2
systemctl start zabbix-agent2
systemctl enable zabbix-agent2

netstat -natp | grep zabbix
tcp6       0      0 :::10050                :::*                    LISTEN      43654/zabbix_agent2 



###在服务端验证 zabbix-agent2 的连通性###
yum install -y zabbix-get				#安装 zabbix 主动获取数据的命令

zabbix_get -s '192.168.230.10' -p 10050 -k 'agent.ping'
1                        #获取键的值是1,连接成功

zabbix_get -s '192.168.239.10' -p 10050 -k 'system.hostname'
zbx-agent01              #获得当前客户机的主机名


####在 Web 页面中添加 agent 主机###
#点击左边菜单栏【配置】中的【主机】,点击【创建主机】
#【主机名称】设置成 zbx-agent01
#【可见的名称】设置成 zbx-agent01-192.168.80.30
#【群组】选择 Linux server
#【Interfaces】的【IP地址】设置成 192.168.80.30

#再点击上方菜单栏【模板】
#【Link new tamplates】搜索 Linux ,选择 Template OS Linux by Zabbix agent
#点击 【添加】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_06


zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_07


zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_08


zabbix 监控项无法获取值告警 zabbix监控was_客户端_09


zabbix 监控项无法获取值告警 zabbix监控was_服务端_10


zabbix 监控项无法获取值告警 zabbix监控was_客户端_11

3.自定义监控内容

案列:自定义监控客户端服务器登录的人数
需求:限制登录人数不超过 3 个,超过 3 个就发出报警信息

#在客户端创建自定义 key
1.明确需要执行的 linux 命令
who | wc -l

2.创建 zabbix 的监控项配置文件,用于自定义 key
vim /etc/zabbix/zabbix_agent2.conf
#可以将自定义的监控项配置文件创建在 zabbix_agent2.d 目录中
268 Include=/etc/zabbix/zabbix_agent2.d/*.conf
#自定义监控项的格式如下
291 #	Format: UserParameter=<key>,<shell command>

cd /etc/zabbix/zabbix_agent2.d/

vim user_login.conf
UserParameter=login.user,who | wc -l
systemctl restart zabbix-agent2

#在服务端验证新建的监控项
zabbix_get -s '192.168.239.10' -p 10050 -k 'login.user'

1.创建模板

点击左边菜单栏【配置】中的【模板】,点击【创建模板】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_12

【模板名称】设置成 Template Login User
【可见的名称】设置成 Template Login User
【群组】选择 Template
【描述】可自定义

点击 【添加】,此时就可在【链接的模板】中搜索到 Template Login User 了

zabbix 监控项无法获取值告警 zabbix监控was_服务端_13

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_14

2.创建应用集

(用于管理监控项的)

点击上方菜单栏【应用集】,点击【创建应用集】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_15

【名称】设置成 Login User
点击 【添加】

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_16

3.创建监控项

点击上方菜单栏【监控项】,点击【创建监控项】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_17

【名称】设置成 Number of login users
【键值】设置成 login.user #键值必须要与自定义的监控项配置文件中设置的保持一致
【更新间隔】设置成 10s
【历史数据保留时长】Storage period 30d #保留时间可自定义设置
点击 【添加】

zabbix 监控项无法获取值告警 zabbix监控was_服务端_18

4.创建触发器

(当监控项获取到监控的值后和触发器预设的值进行对比,判断是否报警)
点击上方菜单栏【触发器】,点击【创建触发器】

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_19

【名称】设置成 Number of login users is greater than 3
【严重性】设置成 一般严重
【表达式】点击添加,【监控项】点击选择 Number of login users,【功能】选择 last(),【结果】选择 > 3,点击 【插入】
点击 【添加】

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_20

zabbix 监控项无法获取值告警 zabbix监控was_服务端_21

5.创建图形

点击上方菜单栏【图形】,点击【创建图形】
【名称】设置成 Number of login users
【宽】、【高】可直接采用默认值
【监控项】点击添加勾选相关监控项 Number of login users,【功能】选择 最大,其它可保持默认值
点击 【添加】

zabbix 监控项无法获取值告警 zabbix监控was_服务端_22

6.将主机与模板关联起来

(一个主机可以关联多个模板)
点击左边菜单栏【配置】中的【主机】,点击你要关联的主机

zabbix 监控项无法获取值告警 zabbix监控was_客户端_23

点击上方菜单栏【模板】,【Link new tamplates】搜索 login,选择 Template Login User,点击【更新】

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_24

此时就点击【监测】中的【主机】,点击你关联主机的【图形】,即可查看到相关的监控项指标

zabbix 监控项无法获取值告警 zabbix监控was_客户端_25

7.设置邮件报警

点击左边菜单栏【管理】中的【报警媒介类型】,点击【创建媒体类型】

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_26

【名称】设置成 qq_Email
【SMTP服务器】设置成 smtp.qq.com
【SMTP服务器端口】设置成 25
【SMTP HELO】设置成 qq.com
【SMTP电邮】设置成 自己的邮箱地址,例如 qwe4546456@qq.com
【认证】选择 用户名和密码
【用户名称】设置成 自己的邮箱地址,例如 qwe4546456@qq.com
【密码】可登录QQ邮箱页面,点击【设置】-->【账户】中的【生成授权码】,通过短信获取授权码
【描述】可自定义

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_27

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_28

点击上方菜单栏【Message templates】,点击【添加】,【Message type】选择 问题,点击【更新】
点击 【添加】,并测试功能

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_29

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_30


zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_31

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_32

点击左边菜单栏【User settings】-->【报警媒介】,点击【添加】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_33

【类型】选择 qq_Email
【收件人】设置成 qwe4546456@wo.cn
【当启用时】设置成 1-7,00:00-24:00
点击 【添加】
再点击 【更新】

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_34

zabbix 监控项无法获取值告警 zabbix监控was_服务端_35

点击左边菜单栏【配置】中的【动作】

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_36

选择相对应的动作名称点击进入,点击 【添加】
【类型】选择 触发器,【触发器】点击选择 Nunber of login users is greater than 3
点击【启用】

zabbix 监控项无法获取值告警 zabbix监控was_服务端_37

zabbix 监控项无法获取值告警 zabbix监控was_服务端_38

8.测试邮件报警

增加测试客户端的用户登录数超过触发器预设的值,查看【监测】-->【仪表盘】,确认报警

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_39

zabbix 监控项无法获取值告警 zabbix监控was_服务端_40

4.zabbix 自动发现与自动注册

自动发现

zabbix 自动发现(对于 agent2 是被动模式)
zabbix server 主动的去发现所有的客户端,然后将客户端的信息登记在服务端上。
缺点是如果定义的网段中的主机数量多,zabbix server 登记耗时较久,且压力会较大。

1.确保客户端上的 zabbix-agent2 服务状态正常
systemctl is-active zabbix-agent2.service 
active

2.在 Web 页面删除原有的客户端主机
点击左边菜单栏【配置】中的【主机】,勾选原有的客户端主机,点击 删除

3.在服务端和客户端上配置 hosts 解析
vim /etc/hosts
192.168.239.20 zbx-server
192.168.239.10 zbx-agent01

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_41


zabbix 监控项无法获取值告警 zabbix监控was_服务端_42

4.在 Web 页面配置自动发现
点击左边菜单栏【配置】中的【自动发现】,点击【创建发现规则】

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_43

【名称】设置成 mynetwork

【IP范围】设置成 192.168.80.1-254

【更新间隔】设置成 30s

【检查】点击【添加】,【检查类型】选择 Zabbix 客户端,【端口范围】设置成 10050,【键值】设置成 system.uname

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_44

【设备唯一性准则】选择 IP地址

【主机名称】选择 DNS名称

【可见的名称】选择 主机名称

勾选 【已启用】,点击 【更新】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_45

点击左边菜单栏【配置】中的【动作】,上方菜单选择 【Discovery actions】

勾选 【Auto discovery. Linux servers.】,点击 【启用】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_46

点击左边菜单栏【配置】中的【主机】刷新,等待一段时间后即可刷新出自动发现的客户端主机

可在服务端查看 zabbix 日志

tail -f /var/log/zabbix/zabbix_server.log

......

6601:20210922:225044.115 enabling Zabbix agent checks on host "zbx-agent01": host became available

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_47


zabbix 监控项无法获取值告警 zabbix监控was_服务端_48

zabbix 自动注册

(对于 agent2 是主动模式)
zabbix agent2 会主动上报自己的信息,发给 zabbix server。
缺点是可能因为配置文件配置错误或者网络不通等原因导致 zabbix agent2 可能找不到 zabbix server。

1.环境准备

点击左边菜单栏【配置】中的【自动发现】,勾选发现规则,点击 禁用

点击左边菜单栏【配置】中的【主机】,勾选原有的客户端主机,点击 删除

zabbix 监控项无法获取值告警 zabbix监控was_zabbix 监控项无法获取值告警_49


zabbix 监控项无法获取值告警 zabbix监控was_客户端_50

vim /etc/hosts
192.168.80.20 zbx-server
192.168.80.30 zbx-agent01

2.修改 zabbix-agent2 配置文件
vim /etc/zabbix/zabbix_agent2.conf
......
HostnameItem=system.hostname #139行,取消注释

egrep -v "#|$" /etc/zabbix/zabbix_agent2.conf

PidFile=/var/run/zabbix/zabbix_agent2.pid

LogFile=/var/log/zabbix/zabbix_agent2.log

LogFileSize=0

Server=192.168.80.20

ServerActive=192.168.80.20

Hostname=zbx-agent01

HostnameItem=system.hostname

Include=/etc/zabbix/zabbix_agent2.d/*.conf

ControlSocket=/tmp/agent.sock

systemctl restart zabbix-agent2.service

zabbix 监控项无法获取值告警 zabbix监控was_客户端_51

3.在 Web 页面配置自动注册

点击左边菜单栏【配置】中的【动作】,上方菜单选择 【Autoregistration actions】,点击【创建动作】

zabbix 监控项无法获取值告警 zabbix监控was_客户端_52

【名称】设置成 Auto registration

点击 【添加】,【类型】选择 主机名称,【操作者】选择 包含,【值】设置成 zbx-agent01

zabbix 监控项无法获取值告警 zabbix监控was_服务端_53

点击上方菜单栏【操作】,点击【添加】,【操作类型】选择 添加主机,点击 【add】
再点击【添加】,【操作类型】选择 添加到主机群组,【主机群组】选择 Linux servers,点击 【add】
再点击【添加】,【操作类型】选择 与模板关联,【模板】搜索 Linux,选择 Template OS Linux by Zabbix agent,点击 【add】
点击下方的【添加】

点击左边菜单栏【配置】中的【主机】刷新,等待一段时间后即可刷新出自动发现的客户端主机

zabbix 监控项无法获取值告警 zabbix监控was_菜单栏_54

在服务端查看 zabbix 日志

tail -f /var/log/zabbix/zabbix_server.log

zabbix 监控项无法获取值告警 zabbix监控was_服务端_55