阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Zabbix 3.0 从入门到精通(Zabbix使用详解)

391次阅读
没有评论

共计 18158 个字符,预计需要花费 46 分钟才能阅读完成。

发布时使用的系统版本为: CentOS Linux release 7.4.1708 (Core) 内核版本为:3.10.0-693.el7.x86_64

第 1 章 Zabbix 监控

1.1 为什么要监控

  在需要的时刻,提前提醒我们服务器出问题了

  当出问题之后,可以找到问题的根源

    网站 / 服务器 的可用性

1.1.1 网站可用性

在软件系统的高可靠性(也称为可用性,英文描述为 HA,High Available)里有个衡量其可靠性的标准——X 个 9,这个 X 是代表数字 3~5。X 个 9 表示在软件系统 1 年时间的使用过程中,系统可以正常使用时间与总时间(1 年)之比,我们通过下面的计算来感受下 X 个 9 在不同级别的可靠性差异。

 1 个 9:(1-90%)*365=36.5 天,表示该软件系统在连续运行 1 年时间里最多可能的业务中断时间是 36.5 天
    2 个 9:(1-99%)*365=3.65 天,表示该软件系统在连续运行 1 年时间里最多可能的业务中断时间是 3.65 天
    3 个 9:(1-99.9%)*365*24=8.76 小时,表示该软件系统在连续运行 1 年时间里最多可能的业务中断时间是 8.76 小时。4 个 9:(1-99.99%)*365*24=0.876 小时 =52.6 分钟,表示该软件系统在连续运行 1 年时间里最多可能的业务中断时间是 52.6 分钟。5 个 9:(1-99.999%)*365*24*60=5.26 分钟,表示该软件系统在连续运行 1 年时间里最多可能的业务中断时间是 5.26 分钟。6 个 9:(1-99.9999%)*365*24*60*60=31 秒,示该软件系统在连续运行 1 年时间里最多可能的业务中断时间是 31 秒

1.2 监控什么东西

监控一切需要监控的东西,只要能够想到,能够用命令实现的都能用来监控

1.2.1 监控范畴

Zabbix 3.0 从入门到精通(Zabbix 使用详解)

1.3 怎么来监控

1.3.1 远程管理服务器

如果想 远程管理服务器 就有远程管理卡,比如 Dell idRAC,HP ILO,IBM IMM

1.3.2 监控硬件

查看硬件的温度 / 风扇转速,电脑有鲁大师,服务器就有 ipmitool。

使用 ipmitool 实现对服务器的命令行远程管理

yum -y install OpenIPMI ipmitool  #->IPMI 在物理机可以成功,虚拟机不行

[root@KVM ~]# ipmitool sdr type Temperature
Temp             | 01h | ns  |  3.1 | Disabled
Temp             | 02h | ns  |  3.2 | Disabled
Temp             | 05h | ns  | 10.1 | Disabled
Temp             | 06h | ns  | 10.2 | Disabled
Ambient Temp     | 0Eh | ok  |  7.1 | 22 degrees C
Planar Temp      | 0Fh | ns  |  7.1 | Disabled
IOH THERMTRIP    | 5Dh | ns  |  7.1 | Disabled
CPU Temp Interf  | 76h | ns  |  7.1 | Disabled
Temp             | 0Ah | ns  |  8.1 | Disabled
Temp             | 0Bh | ns  |  8.1 | Disabled
Temp             | 0Ch | ns  |  8.1 | Disabled

1.3.3 查看 cpu 相关

lscpu、uptime、top、htop vmstat mpstat

  其中 htop 需要安装,安装依赖与 epel 源。

[linuxidc@linuxidc ~]$lscpu
Architecture:          x86_64
CPU op-mode(s):        32-bit, 64-bit
Byte Order:            Little Endian
CPU(s):                1
On-line CPU(s) list:   0
Thread(s) per core:    1
Core(s) per socket:    1
Socket(s):             1
NUMA node(s):          1
Vendor ID:             GenuineIntel
CPU family:            6
Model:                 85
Model name:            Intel(R) Xeon(R) Platinum 8163 CPU @ 2.50GHz
Stepping:              4
CPU MHz:               2494.150
BogoMIPS:              4988.30
Hypervisor vendor:     KVM
Virtualization type:   full
L1d cache:             32K
L1i cache:             32K
L2 cache:              1024K
L3 cache:              33792K
NUMA node0 CPU(s):     0

1.3.4 内存够不够可以用

free

[linuxidc@linuxidc ~]$free -h
             total       used       free     shared    buffers     cached
Mem:          996M       867M       128M       712K       145M       450M
-/+ buffers/cache:       271M       725M
Swap:         1.0G         0B       1.0G

1.3.5 磁盘剩多少写的快不快可以用

df、dd、iotop

[linuxidc@linuxidc ~]$df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/vda1        40G   24G   15G  62% /
tmpfs           499M   20K  499M   1% /dev/shm
/dev/vdb1        20G  4.4G   15G  24% /data

1.3.6 监控网络

iftop nethogs

iftop   监控主机间流量  -i 指定监控网卡
nethogs 监控进程流量

1.4 监控工具总览

mrtg 流量监控出图

nagios 监控

cacti  流量监控出图

zabbix 监控 +出图

1.5 zabbix 介绍

Zabbix 是由 Alexei Vladishev 开发的一种网络监视、管理系统,基于 Server-Client 架构。可用于监视各种网络服务、服务器和网络机器等状态。

使用各种 Database-end 如 MySQL, PostgreSQL, SQLite, Oracle 或 IBM DB2 储存资料。Server 端基于 C 语言、Web 管理端 frontend 则是基于 PHP 所制作的。Zabbix 可以使用多种方式监视。可以只使用 Simple Check 不需要安装 Client 端,亦可基于 SMTP 或 HTTP … 各种协定做死活监视。

在客户端如 UNIX, Windows 中安装 Zabbix Agent 之后,可监视 CPU Load、网络使用状况、硬盘容量等各种状态。而就算没有安装 Agent 在监视对象中,Zabbix 也可以经由 SNMP、TCP、ICMP、利用 IPMI、SSH、telnet 对目标进行监视。

另外,Zabbix 包含 XMPP 等各种 Item 警示功能。

1.5.1 zabbix 的组成

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

zabbix 官网: https://www.zabbix.com

zabbix 主要由 2 部分构成 zabbix server 和 zabbix agent

zabbix proxy 是用来管理其他的 agent,作为代理

1.5.2 zabbix 监控范畴

²  硬件监控:Zabbix IPMI Interface

²  系统监控:Zabbix Agent Interface

²  Java 监控:ZabbixJMX Interface

²  网络设备监抟:Zabbix SNMP Interface

²  应用服务监控:Zabbix Agent UserParameter

²  MySQL 数据库监控:percona-monitoring-pldlgins

²  URL 监控:Zabbix Web 监控

第 2 章 安装 zabbix

2.1 环境检查

[root@m01 ~]# cat /etc/RedHat-release
CentOS Linux release 7.4.1708 (Core)

[root@m01 ~]# uname -r
3.10.0-693.el7.x86_64

[root@m01 ~]# getenforce
Disabled

[root@m01 ~]# systemctl status firewalld.service
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
   Active: inactive (dead)
     Docs: man:firewalld(1)

2.2 安装 zabbix 过程

2.2.1 安装方式选择

编译安装(服务较多,环境复杂)

yum 安装(干净环境)

使用 yum 需要镜像 yum 源  http://www.linuxidc.com/Linux/2017-11/148766.htm

2.2.2 服务端快速安装脚本

#!/bin/bash
#linuxidc

#设置解析 注意:网络条件较好时,可以不用自建 yum 源
# echo '10.0.0.1 mirrors.aliyuncs.com mirrors.aliyun.com repo.zabbix.com' >> /etc/hosts

#安装 zabbix 源、aliyun YUM 源
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix-release-3.0-1.el7.noarch.rpm

#安装 zabbix 
yum install -y zabbix-server-mysql zabbix-web-mysql

#安装启动 mariadb 数据库
yum install -y  mariadb-server
systemctl start mariadb.service

#创建数据库
mysql -e 'create database zabbix character set utf8 collate utf8_bin;'
mysql -e 'grant all privileges on zabbix.* to zabbix@localhost identified by"zabbix";'

#导入数据
zcat /usr/share/doc/zabbix-server-mysql-3.0.13/create.sql.gz|mysql -uzabbix -pzabbix zabbix

#配置 zabbixserver 连接 mysql
sed -i.ori '115a DBPassword=zabbix' /etc/zabbix/zabbix_server.conf

#添加时区
sed -i.ori '18a php_value date.timezone  Asia/Shanghai' /etc/httpd/conf.d/zabbix.conf

#解决中文乱码
yum -y install wqy-microhei-fonts
\cp /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf

#启动服务
systemctl start zabbix-server
systemctl start httpd

#写入开机自启动
chmod +x /etc/rc.d/rc.local
cat >>/etc/rc.d/rc.local<<EOF
systemctl start mariadb.service
systemctl start httpd
systemctl start zabbix-server
EOF

#输出信息
echo "浏览器访问 http://`hostname -I|awk'{print $1}'`/zabbix"

2.2.3 客户端快速部署脚本

#!/bin/bash
#linuxidc

#设置解析
echo '10.0.0.1 mirrors.aliyuncs.com mirrors.aliyun.com repo.zabbix.com' >> /etc/hosts

#安装 zabbix 源、aliyu nYUM 源
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix-release-3.0-1.el7.noarch.rpm

#安装 zabbix 客户端
yum install zabbix-agent -y
sed -i.ori 's#Server=127.0.0.1#Server=172.16.1.61#' /etc/zabbix/zabbix_agentd.conf
systemctl start  zabbix-agent.service

#写入开机自启动
chmod +x /etc/rc.d/rc.local
cat >>/etc/rc.d/rc.local<<EOF
systemctl start  zabbix-agent.service
EOF

2.3 检测连通性

2.3.1 服务端安装 zabbix-get 检测工具

yum install zabbix-get

2.3.2 在服务端进行测试

注意:只能在服务端进行测试

zabbix_get -s 172.16.1.61 -p 10050 -k "system.cpu.load[all,avg1]"
zabbix_get -s 172.16.1.21 -p 10050 -k "system.cpu.load[all,avg1]"

测试结果

[root@m01 ~]# zabbix_get -s 172.16.1.61 -p 10050 -k "system.cpu.load[all,avg1]"
0.000000

[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "system.cpu.load[all,avg1]"
0.000000

第 3 章 web 界面操作

3.1 zabbix 的 web 安装

3.1.1 使用浏览器访问

http://10.0.0.61/zabbix/setup.php

Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  在检测信息时,可查看具体的报错信息进行不同的解决

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  选择 mysql 数据库,输入密码即可

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  host 与 port 不需要修改,name 自定义

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

确认信息, 正确点击下一步

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  安装完成、点击 finsh

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

      进入登陆界面  账号 Admin 密码 zabbix  注意 A 大写

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

3.2 添加监控信息

3.2.1 修改监控管理机 zabbix server

配置 >> 主机

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

主机名称:要与主机名相同,这是 zabbix server 程序用的

可见名称:显示在 zabbix 网页上的,给我们看的

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

  修改后,要将下面的已启用要勾上

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  添加完成就有了管理机的监控主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

3.2.2 添加新的主机

配置 >> 主机 >> 创建主机

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

注意勾选以启用

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  然后添加模板,选择 linux OS,先点小添加,再点大添加。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  添加完成,将会又两条监控主机信息

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

3.2.3 查看监控内容

检测中  >> 最新数据

  在最新数据中需要筛选,

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  输入 ip 或者名字都能够搜索出来

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

在下面就会列出所有的监控项

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

3.2.4 查看图像

检测中 >> 图形

  选择正确的主机。选择要查看的图形即可出图

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

第 4 章 自定义监控与监控报警

4.1 自定义监控

4.1.1 说明

zabbix 自带模板 Template OS Linux (Template App Zabbix Agent)提供 CPU、内存、磁盘、网卡等常规监控,只要新加主机关联此模板,就可自动添加这些监控项。

需求:服务器登陆人数不能超过三人,超过三人报警

4.1.2 预备知识

自定义 key 能被 server 和 agent 认可

# 正确的 key
[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "system.uname"
Linux cache01 3.10.0-693.el7.x86_64 #1 SMP Tue Aug 22 21:09:27 UTC 2017 x86_64 
# 没有登记的,自定义的 key
[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "login-user"
ZBX_NOTSUPPORTED: Unsupported item key. 
# 写错的 key
[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "system.uname1"
ZBX_NOTSUPPORTED: Unsupported item key.

4.2 实现自定义监控

4.2.1 自定义语法

UserParameter=<key>,<shell command>
UserParameter=login-user,who|wc -l
UserParameter=login-user,/bin/sh /server/scripts/login.sh

4.2.2 agent 注册

[root@cache01 ~]# cd /etc/zabbix/zabbix_agentd.d/

[root@cache01 zabbix_agentd.d]# vim userparameter_login.conf
UserParameter=login-user,who|wc -l
UserParameter=login-user2,who|wc -l
UserParameter=login-user3,who|wc -l

  注意:key 名字要唯一,多个 key 以行为分割

# 修改完成后重启服务

[root@cache01 zabbix_agentd.d]# systemctl restart zabbix-agent.service

  在 server 端进行 get 测试

[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "login-user"
3

[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "login-user2"
3

[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "login-user3"
3

[root@m01 ~]# zabbix_get -s 172.16.1.21 -p 10050 -k "login-user4"
ZBX_NOTSUPPORTED: Unsupported item key.

4.2.3 在 server 端注册(web 操作)

①  创建模板

配置 >> 模板 >> 创建模板

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

点击添加,即可创建出来模板

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  查看创建出来的模板。↑

②  创建应用集

应用集类似(目录 / 文件夹),其作用是给监控项分类。

点击 应用集 >> 创建应用集

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

      自定义应用集的名称,然后点击添加

③  创建监控项

监控项 >> 创建监控项

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

键值 — key, 即前面出创建的 login-user。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  注意:创建监控项的时候,注意选择上应用集,即之前创建的安全。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

④  创建触发器

触发器的作用:当监控项获取到的值达到一定条件时就触发报警

(根据需求创建)

触发器 >> 创建触发器

创建触发器,自定义名称,该名称是报警时显示的名称。

  表达式,点击右边的添加,选择 表达式

  严重性自定义。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  表达式的定义 ,选择 之前创建的监控项,

最新的 T 值为当前获取到的值。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  添加完成,能够在触发器中看到添加的情况

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

⑤  创建图形

以图形的方式展示出来监控信息

图形 >> 创建图形

名称自定义,关联上监控项。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

⑥  主机关联模板

配置 >> 主机

  一个主机可以关联多个模板

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

4.2.4 查看监控的图形

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

4.3 监控报警

4.3.1 第三方报警平台

http://www.onealert.com

  通过 OneAlert 提供的通知分派与排班策略,以及全方位的短信、微信、QQ、电话提醒服务,您可以在最合适的时间,将最重要的信息推送给最合适的人员。

4.3.2 onealert 配置

添加应用,注意添加的式 zabbix

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  实现微信报警需要关注微信公众号即可。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

4.3.3 安装 onealert Agent

1. 切换到 zabbix 脚本目录(如何查看 zabbix 脚本目录):

cd /usr/local/zabbix-server/share/zabbix/alertscripts

#查看 zabbix 脚本目录
vi /etc/zabbix/zabbix_server.conf
查看 AlertScriptsPath

2. 获取 OneITSM agent 包:

wget http://www.onealert.com/agent/release/oneitsm_zabbix_release-1.0.1.tar.gz

3. 解压、安装。

tar -zxf oneitsm_zabbix_release-1.0.1.tar.gz
cd oneitsm/bin
bash install.sh --#个人生成的 key

注:在安装过程中根据安装提示,输入 zabbix 管理地址、管理员用户名、密码

Zabbix 管理地址: http://10.0.0.61/zabbix/
Zabbix 管理员账号: Admin
Zabbix 管理员密码:

4. 当提示 ” 安装成功 ” 时表示安装成功!

验证告警集成

产生新的 zabbix 告警(problem), 动作状态为“已送达”表示集成成功。

4.3.1 如何删除 onealert Agent

①  删除报警媒介类型中的脚本

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

②  删除创建的用户

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

③  删除用户群组

Zabbix 3.0 从入门到精通(Zabbix 使用详解)

④  删除创建的动作

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

4.3.2 触发器响应,发送报警信息

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  在微信和邮件中,均能收到报警信息。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  注意:当状态改变的时候才会发邮件

    好 –> 坏

    坏 –> 好

4.4 监控可视化

4.4.1 聚合图形

最新数据 >> 图形

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  自定义名称

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  点击聚合图形的名称,进行更改,添加要显示的图形即可。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

4.4.2 幻灯片

添加幻灯片

监测中 >> 复合图形 >> 幻灯片演示

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  创建幻灯片,名称自定,选择要显示的

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  幻灯片根据设定的时间自动播放

4.5 模板的共享

4.5.1 主机共享

在主机页打开,全选后点击导出

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  导入

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

4.5.2 模板共享

https://github.com/zhangyao8/zabbix-community-repos

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

第 5 章 监控全网服务器

5.1 需求说明

实际需求:

公司已经有了 100 台服务器,现在需要使用 zabbix 全部监控起来。

5.2 规划方案

常规监控:cpu,内存,磁盘,网卡  问题:怎样快速添加 100 台机器

  方法 1:使用克隆的方式

    方法 2:自动注册和自动发现

    方法 3:调用 zabbix api 接口  curl、python

         开发自己的运维平台兼容 zabbix 的通道

服务监控,url监控等特殊监控:自定义监控

5.2.1 api 接口使用(curl

curl -i -X POST -H 'Content-Type:application/json' -d'{"jsonrpc":"2.0","method":"user.login","params":{"user":"Admin","password":"zabbix"},"auth": null,"id":0}' "http://10.0.0.61/zabbix/api_jsonrpc.php"

    curl -i -X POST -H 'Content-Type:application/json' -d'    {"jsonrpc": "2.0",
        "method": "host.get",
        "params": {"output": ["hostid",
                "host"
            ],
            "selectInterfaces": ["interfaceid",
                "ip"
            ]
        },
        "id": 2,
        "auth": "6a450a8fc3dce71fd310cfe338746578"
    }' http://10.0.0.61/zabbix/api_jsonrpc.php

5.3 具体实施规划

5.3.1 硬件、系统、网络监控

所有集群节点(所有虚拟机)都监控上

交换机,路由器监控(简单方法:换成端口对应服务器网卡流量监控;标准方法:监控交换机的网卡)

snmp 监控

5.3.2 应用服务监控

1. 监控备份服务器,简单方法是监控 rsync 端口,如果有其他更佳方案可以说明;

方法 1:监控 873 端口 net.tcp.port[,873]
    方法 2:模拟推送拉取文件

2. 监控 NFS 服务器,使用监控 NFS 进程来判断 NFS 服务器正常,如果有其他更佳方案可以说明;

方法 1:端口(通过 111 的 rpc 端口获取 nfs 端口)net.tcp.port[,111]
    方法 2:showmount -e ip|wc -l

3. 监控 MySQL 服务器,简单方法监控 mysql 的 3306 端口,或者使用 zabbix 提供的 Mysql 模板,如果有其他更佳方案可以说明;

方法 1:端口(通过 3306 的 mysql 端口)net.tcp.port[,3306]
    方法 2:mysql 远程登录
    方法 3:使用 zabbix agent 自带的模板及 key

4. 监控 2 台 web 服务器,简单方法监控 80 端口,如果有其他更佳方案可以说明;

方法 1:端口(通过 80 的 web 端口)net.tcp.port[,80]
    方法 2:看网页状态码、返回内容==zabbix 自带 WEB 检测

5. 监控 URL 地址来更精确的监控我们的网站运行正常;

使用 zabbix 自带的监控 Web 监测 进行监控

6. 监控反向代理服务器,PPTP 服务器等你在期中架构部署的服务。

nginx,pptp
ntp 端口 udp 123

7. 监控 Nginx 的 7 种连接状态。

自定义监控

5.3.3 监控服务通用方法

1. 监控端口 netstat ss lsof  ==》wc -l

2. 监控进程 ps -ef|grep 进程 |wc -l  试运行一下

3. 模拟客户端的使用方式监控服务端

    web  ==》curl

    mysql ==》select insert

    memcache ==》set 再 get

5.4 实施全网监控

安装客户端脚本,for centos6

#!/bin/bash

#设置解析
# echo '10.0.0.1 mirrors.aliyuncs.com mirrors.aliyun.com repo.zabbix.com' >> /etc/hosts

#安装 zabbix 源、aliyu nYUM 源
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/6/x86_64/zabbix-release-3.0-1.el6.noarch.rpm

yum clean all
yum clean all
#安装 zabbix 客户端
yum install zabbix-agent -y
sed -i.ori 's#Server=127.0.0.1#Server=172.16.1.61#' /etc/zabbix/zabbix_agentd.conf
/etc/init.d/zabbix-agent start

#写入开机自启动
chmod +x /etc/rc.d/rc.local
cat >>/etc/rc.d/rc.local<<EOF
/etc/init.d/zabbix-agent start
EOF

5.4.1 使用自动发现规则

添加自动发现规则

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

  创建发现动作

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

  查看自动发现的机器。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.2 监控备份服务器

利用系统自带键值进行监控net.tcp.listen[port] 创建新的模板

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

在服务端进行测试

[root@m01 ~]# zabbix_get -s 172.16.1.41 -p 10050 -k "net.tcp.listen[873]"
1

# 1 为端口在监听 0 为端口未监听

将模板添加到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.3 监控 NFS 服务器

创建 nfs 监控模板

使用 proc.num[<name>,<user>,<state>,<cmdline>]  键值,检测 nfs 进程的数量

 Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

在服务端进行测试

[root@m01 ~]# zabbix_get -s 172.16.1.31 -p 10050 -k "proc.num[,,,rpc]"
5

[root@m01 ~]# zabbix_get -s 172.16.1.31 -p 10050 -k "proc.num[nfsd,,,]
8

 

将模板绑定到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.4 监控 MySQL 服务器

将自带的 mysqlkey 值加上 mysql 的账户密码,否则不能获取到数据。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

使用系统自带模板  net.tcp.port[<ip>,port] 利用自带的监控端口键值进行监控

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

添加新的 mysql 监控项端口

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

[root@m01 ~]# zabbix_get -s 172.16.1.51 -p 10050 -k "net.tcp.port[,3306]"
1

#检查是否能建立 TCP 连接到指定端口。返回 0 - 不能连接;1 - 可以连接

将模板关联到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.5 监控 web 服务器

创建监控模板 监控 nginx 服务与 80 端口

proc.num[<name>,<user>,<state>,<cmdline>]   进程数。返回整数
    net.tcp.port[<ip>,port] 检查是否能建立 TCP 连接到指定端口。返回 0 - 不能连接;1 - 可以连接

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

[root@m01 ~]# zabbix_get -s 172.16.1.8 -p 10050 -k "proc.num[,,,nginx]"
2

[root@m01 ~]# zabbix_get -s 172.16.1.8 -p 10050 -k "net.tcp.port[,80]"
1

将模板关联到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.6 监控 URL 地址

创建监测页面

echo ok >> /application/nginx/html/www/check.html

 

测试监控面页

[root@web03 ~]# for ip in 7 8 9 ;do curl 10.0.0.$ip/check.html ;done
ok
ok
ok

创建 web 监测模板

  创建应用集

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  创建 Web场景

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  创建图形

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

将模板关联到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

监测结果

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.7 监控反向代理服务器

创建自定义 key

[root@lb01 ~]# cat  /etc/zabbix/zabbix_agentd.d/userparameter_nk.conf
UserParameter=keep-ip,ip a |grep 10.0.0.3|wc -l

在服务端测试

[root@m01 ~]# zabbix_get -s 172.16.1.5  -p 10050 -k "keep-ip"
1

[root@m01 ~]# zabbix_get -s 172.16.1.6  -p 10050 -k "keep-ip"
0

在 web 界面添加模板

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

将模板关联到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

5.4.8 监控 Nginx 的 7 种连接状态

nginx 服务器显示 status
……
    location /status {
           stub_status on;
           access_log off;
    }
……

 

[root@web01 ~]# for ip in 7 8 9 ;do curl 172.16.1.$ip/status ;done
Active connections: 1
server accepts handled requests
 73 73 69
Reading: 0 Writing: 1 Waiting: 0

Active connections: 1
server accepts handled requests
 134 134 127
Reading: 0 Writing: 1 Waiting: 0

Active connections: 1
server accepts handled requests
 7 7 7
Reading: 0 Writing: 1 Waiting: 0

在 nginx 服务器上添加 key

cat >/etc/zabbix/zabbix_agentd.d/userparameter_nginx_status.conf <<'EOF'
UserParameter=nginx_active,curl -s  127.0.0.1/status|awk '/Active/ {print $NF}'
UserParameter=nginx_accepts,curl -s  127.0.0.1/status|awk 'NR==3 {print $1}'
UserParameter=nginx_handled,curl -s  127.0.0.1/status|awk 'NR==3 {print $2}'
UserParameter=nginx_requests,curl -s  127.0.0.1/status|awk 'NR==3 {print $3}'
UserParameter=nginx_reading,curl -s  127.0.0.1/status|awk 'NR==4 {print $2}'
UserParameter=nginx_writing,curl -s  127.0.0.1/status|awk 'NR==4 {print $4}'
UserParameter=nginx_waiting,curl -s  127.0.0.1/status|awk 'NR==4 {print $6}'
EOF

服务端测试

[root@m01 ~]# zabbix_get -s 172.16.1.7  -p 10050 -k "nginx_waiting"
0

[root@m01 ~]# zabbix_get -s 172.16.1.8  -p 10050 -k "nginx_waiting"
0

[root@m01 ~]# zabbix_get -s 172.16.1.9  -p 10050 -k "nginx_waiting"
0

在 zabbix-web 上添加

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

监控项

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

添加图形

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

将模板关联到主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

查看添加的图形

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

Zabbix 3.0 从入门到精通(Zabbix 使用详解)

第 6 章 自动发现与自动注册

6.1 自动注册与自动注册

6.1.1 简介

自动发现:

zabbix Server 主动发现所有客户端,然后将客户端登记自己的小本本上,缺点 zabbix server 压力山大(网段大,客户端多),时间消耗多。

自动注册:

zabbix agent 主动到 zabbix Server 上报到,登记;缺点 agent 有可能找不到 Server(配置出错)

6.1.2 两种模式

被动模式:默认  agent 被 server 抓取数据(都是在 agent 的立场上说)主动模式:agent 主动将数据发到 server 端(都是在 agent 的立场上说)

     注意: 两种模式都是在 agent上进行配置

     zabbix 的使用要在 hosts文件中预先做好主机名的解析

6.2 自动发现 – 被动模式

第一个里程碑:完成之前的安装

zabbix Server 安装完毕

  第二个里程碑:配置 agent 客户端

zabbix agent 安装完毕,注意配置 Server=172.16.1.61

  第三个里程碑:在 web 界面上进行配置

web 界面:配置 >> 自动发现 >> Local network
        使用自带的自动发现规则(进行修改)即可

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

    在 ip 范围内输入 ip,注意格式;延迟在实际的生产环境中要大一些,实验环境可以小一些

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  创建发现动作

配置 >> 动作 >> Auto discovery. Linux servers.

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

①  配置动作

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

②  在条件中添加条件,让添加更准确

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

③  在操作中添加

a)  添加主机与启用主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

    然后等待者客户端自动上门就好?

6.3 自动注册 – 主动模式

第一个里程碑:zabbix Server 安装完毕(完成)

zabbix Server 安装完毕

  第二个里程碑:zabbix agent 安装完毕,需要额外增加的配置

vim /etc/zabbix/zabbix_agentd.conf
ServerActive=172.16.1.61
# Hostname=Zabbix server
HostnameItem=system.hostname
 
systemctl restart zabbix-agent.service
netstat -tunlp|grep zabbix

    源文件与修改后对比

Zabbix 3.0 从入门到精通(Zabbix 使用详解)Zabbix 3.0 从入门到精通(Zabbix 使用详解)

   第三个里程碑:在 web 见面上进行配置

1 配置 >> 动作 >> 事件源(自动注册) >> 创建动作

Zabbix 3.0 从入门到精通(Zabbix 使用详解) 

    创建动作,添加名称即可

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

    条件中也无需修改

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

    在动作中添加动作

(添加主机、添加到主机群组、链接到模板)

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

    添加完动作后,等待就行了

    注意:重启客户端可以加速发现。但是在生产环境中勿用。

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

第 7 章 分布式监控与 SNMP 监控

7.1 分布式监控

7.1.1 作用

  分担压力,减轻负载

  多机房监控

zabbix Server  ===》zabbix agent(只能同一个局域网监控)

分担压力,降低负载

zabbix Server ===》zabbix proxy  ===》zabbix agent1 agent2 agent3。。。172.16.1.61           172.16.1.21        172.16.1.0/24
                ===》zabbix proxy  ===》zabbix agent4 agent5 agent6。。。

多机房监控

zabbix Server(北京)           ==》zabbix proxy(每个机房搭建)==》zabbix agent
    122.71.240.233/172.16.1.61          122.71.241.11/172.16.2.21     172.16.2.0/24

7.1.2 环境说明

    zabbix server m01
    zabbix proxy cache01
    zabbix agent  cache01

7.1.3 配置 zabbix proxy

第一个里程碑:配置 zabbix yum 源,并安装 proxy

rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix-release-3.0-1.el7.noarch.rpm
yum install zabbix-proxy-mysql -y

  第二个里程碑:安装数据库

    zabbix  proxy 也需要数据库,这个数据库不是用于存储监控数据的 只是用于存储配置信息

  #安装数据库

yum -y install mariadb-server
systemctl start mariadb.service

  #建立数据库

mysql
create database zabbix_proxy character set utf8 collate utf8_bin;
grant all privileges on zabbix_proxy.* to zabbix@'localhost' identified by 'zabbix';
exit

  #导入数据文件

zcat /usr/share/doc/zabbix-proxy-mysql-3.0.13/schema.sql.gz |mysql -uzabbix -pzabbix zabbix_proxy

  #配置 zabbix proxy 连接数据库

sed -i.ori '162a DBPassword=zabbix' /etc/zabbix/zabbix_proxy.conf
sed -i 's#Server=127.0.0.1#Server=172.16.1.61#' /etc/zabbix/zabbix_proxy.conf
sed -i 's#Hostname=Zabbix proxy#Hostname=cache01#' /etc/zabbix/zabbix_proxy.conf

# Hostname 作为后面添加的代理程序名称,要保持一致

  #启动

systemctl restart zabbix-proxy.service

  #检查端口

[root@cache01 ~]# netstat -lntup |grep zabbix
tcp        0      0 0.0.0.0:10050     0.0.0.0:*       LISTEN      105762/zabbix_agent
tcp        0      0 0.0.0.0:10051   0.0.0.0:*         LISTEN      85273/zabbix_proxy 
tcp6       0      0 :::10050       :::*      LISTEN      105762/zabbix_agent
tcp6       0      0 :::10051  :::*           LISTEN      85273/zabbix_proxy

  第三个里程碑:修改 agent 配置指向 proxy

[root@cache01 ~]# grep ^Server /etc/zabbix/zabbix_agentd.conf
Server=172.16.1.61
ServerActive=172.16.1.61

[root@cache01 ~]# sed -i 's#172.16.1.61#172.16.1.21#g' /etc/zabbix/zabbix_agentd.conf

[root@cache01 ~]# grep ^Server /etc/zabbix/zabbix_agentd.conf
Server=172.16.1.21
ServerActive=172.16.1.21

[root@cache01 ~]# systemctl restart zabbix-agent.service

  第四个里程碑:web 界面添加代理

    管理 >> agent 代理程序 >> 创建代理

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  代理程序名称要填写主机名

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  稍等片刻就能在程序中出现代理

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

  在主机中能发现主机代理

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

7.2 SNMP 监控

7.2.1 使用范围

无法安装 agent  很多前辈的监控软件都可以监控各种设备  都是通过 snmp 监控

snmp simple network manager protocol 简单网络管理协议

   简单网络管理协议(SNMP),由一组网络管理的标准组成,包含一个应用层协议(application layer protocol)、数据库模型(database schema)和一组资源对象。该协议能够支持网络管理系统,用以监测连接到网络上的设备是否有任何引起管理上关注的情况。

7.2.2 安装 snmp 程序

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

7.2.3 配置 snmp 程序

sed -i.ori '57a view systemview   included  .1' /etc/snmp/snmpd.conf
systemctl start snmpd.service

7.2.4 测试 snmp

[root@m01 ~]# snmpwalk -v 2c -c public 127.0.0.1 sysname
SNMPv2-MIB::sysName.0 = STRING: m01

说明:

    # snmpwalk 类似 zabbix_get

# -v 2c  指定使用 snmp 协议的版本  snmp 分为 v1 v2 v3

# -c public  指定暗号

# sysname  类似 zabbix 的 key

7.2.5 在 web 界面进行配置

添加新的主机,注意使用 snmp 接口

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

选择模板,注意使用 SNMP 的模板

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

    添加完成就能够在主机中看到 snmp 监控对的主机

 Zabbix 3.0 从入门到精通(Zabbix 使用详解)

更多 Zabbix 相关教程集合

在 Ubuntu 16.04 服务器上安装 Zabbix 3.2  http://www.linuxidc.com/Linux/2017-07/145519.htm 

CentOS 7 LNMP 环境搭建 Zabbix3.0  http://www.linuxidc.com/Linux/2017-02/140134.htm 

Ubuntu 16.04 安装部署监控系统 Zabbix2.4  http://www.linuxidc.com/Linux/2017-03/141436.htm 

Zabbix 监控安装部署及警报配置  http://www.linuxidc.com/Linux/2017-03/141611.htm 

Zabbix 触发器表达式详解 http://www.linuxidc.com/Linux/2017-03/141921.htm 

Ubuntu 16.04 下安装部署 Zabbix3.0  http://www.linuxidc.com/Linux/2017-02/140395.htm 

CentOS 6.3 下 Zabbix 监控 apache server-status http://www.linuxidc.com/Linux/2013-05/84740.htm 

CentOS 7 下 Zabbix 3.0 安装详解 http://www.linuxidc.com/Linux/2017-03/141716.htm 

CentOS 7.4 安装 Zabbix 3.4  http://www.linuxidc.com/Linux/2017-09/147202.htm

64 位 CentOS 6.2 下安装 Zabbix 2.0.6   http://www.linuxidc.com/Linux/2014-11/109541.htm 

ZABBIX 的详细介绍:请点这里
ZABBIX 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-11/148841.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计18158字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中