开启主机自动发现

⦁选择配置 ->自动发现 ->创建自动发现->ip范围必须连续,不连续的话逗号分开

⦁更新间隔 -> 2s ->更新

⦁检查 -> 选择新的 -> ICMP ping ->更新

⦁动作 ->事件源(自动发现) –>创建动作 ->iP地址

⦁主机IP =192.168.1.1 192.168.1.254

⦁在线/不在线>=1秒

操作(这里是否报警)->删除

⦁点击操作->选择新的标签->操作类型->添加主机->添加

⦁点击操作->选择新的标签->操作类型->添加主机群组->选择一个群组->添加

⦁点击操作->选择新的标签->操作类型->与模板相关联->选择你要添加的模板->添加

⦁点击操作->选择新的标签->操作类型->启用主机->添加

⦁最后点击->自动发现->启用自动发现即可

## 监控进程连接数

⦁首先,直接添加一个主机,我们不要选择模板,直接添加一个裸主机.

⦁其次我们的被控主机安装一下Apache软件,并能在控制端通过zabbix-get命令获取到Apache进程数.

[root@localhost ~]# zabbix_get -s 192.168.1.25 -k proc.num[httpd]
6 [root@localhost ~]# zabbix_get -s 192.168.1.25 -k proc.num[httpd,,,]
6 #以上两种写法相同,具体命令参数应该看文档.

⦁在web界面上,选择监控项->创建监控项->选择键值->修改成proc.num[httpd,,,]->点击添加.

⦁接着点击图形->创建图形->选择创建的自定义key->保存即可.

## 其他常用监控key

同理,我们就可以使用系统默认的监控key来监控内存,CPU以及网络等流量信息,配置过程同上一个案例相同,只是在配置中使用的配置参数略有区别罢了,此处就不再演示了.

基本的数据采集命令:

zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.hostname
localhost.localdomain // 此处才是主机名称 zabbix_get.exe -s 192.168.1.20 -p 10050 -k agent.hostname
centos1 // 此处是我们zabbix中自定义的键值对 zabbix_get.exe -s 192.168.1.20 -p 10050 -k agent.ping
1 zabbix_get.exe -s 192.168.1.20 -p 10050 -k agent.version
4.4.3 // zabbix 的version zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.boottime
1578564779 // 系统启动的时间戳 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.cpu.num
1 // 处理器个数 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.localtime
1578569019 // 当前系统时间戳 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.sw.arch
x86_64 // 返回系统架构 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.sw.os
Linux version 3.10.0-1062.el7.x86_64 (mockbuild@kbuilder.bsys.centos.org) (gcc version 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) ) #1 SMP Wed Aug 7 18:08:02 UTC 2019 // 返回系统详细架构 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.sw.packages[ssh] // 已安装软件列表
[rpm] libssh2-1.8.0-3.el7.x86_64, openssh-7.4p1-21.el7.x86_64, openssh-clients-7.4p1-21.el7.x86_64, openssh-server-7.4p1-21.el7.x86_64 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.uname
Linux localhost.localdomain 3.10.0-1062.el7.x86_64 #1 SMP Wed Aug 7 18:08:02 UTC 2019 x86_64 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.uptime
4438 // 系统运行时长(秒)多少秒使用s/uptime来获取 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.users.num
0 // 登陆用户数 zabbix_get.exe -s 192.168.1.20 -p 10050 -k kernel.maxfiles
96437 // 系统支持最大的open files整数 zabbix_get.exe -s 192.168.1.20 -p 10050 -k kernel.maxproc
65536 // 系统支持最大进程数 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.hw.macaddr
[ens32] 00:50:56:22:6f:d3 // mac 地址列表 >zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.sw.os
Linux version 3.10.0-1062.el7.x86_64 (mockbuild@kbuilder.bsys.centos.org) (gcc version 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) ) #1 SMP Wed Aug 7 18:08:02 UTC 2019 // 操作系统信息

允许远程执行命令:

[root@localhost ~]# vim /etc/zabbix/zabbix_agentd.conf
EnableRemoteCommands=1
[root@localhost ~]# systemctl restart zabbix-agent D:\zabbix> zabbix_get.exe -s 192.168.1.20 -p 10050 -k "system.run[df -h]"
Filesystem Size Used Avail Use% Mounted on
devtmpfs 480M 0 480M 0% /dev
tmpfs 491M 0 491M 0% /dev/shm
tmpfs 491M 7.4M 484M 2% /run
tmpfs 491M 0 491M 0% /sys/fs/cgroup
/dev/mapper/centos-root 27G 1.7G 26G 7% /
/dev/sda1 1014M 136M 879M 14% /boot
tmpfs 99M 0 99M 0% /run/user/0

监控CPU

system.cpu.util[<cpu>,<type>,<mode>]

-CPU:  CPU数量(默认是所有CPU)
-Type: 可用值,idle,nice,user,system,iowait,interrupt,sottrq,steal
-Mode 可用值,avg1(一分钟负载),avg5,avg15 [root@localhost ~]# zabbix_get -s 192.168.1.25 -k system.cpu.util[,,avg1]
0.016692 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.cpu.num
1 // cpu 个数 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.cpu.util
0.016461 // cpu 利用率百分比 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.hw.cpu // cpu 详细信息
processor 0: GenuineIntel Intel(R) Celeron(R) CPU E3500 @ 2.70GHz working at 2700MHz

监控内存

proc.mem[<name>,<user>,<mode>,<cmdline>,<memtype>]

-name    进程名(默认所有进程)
-user 用户名(默认所有用户)
-mode 可选值,avg,max,min,sum
-cmdline 命令过滤 [root@localhost ~]# zabbix_get -s 192.168.1.25 -k proc.mem[httpd,,,]
1376378880
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k proc.mem[]
6479925248 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.swap.in
0 // Swap in (f内存到磁盘) .数字 zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.swap.out
0 //Swap out (f内存到磁盘) .数字
zabbix_get.exe -s 192.168.1.20 -p 10050 -k system.swap.size
2147479552 // 交换分区大小字节或者百分比 mode - total (默认), active, anon, buffers, cached, exec, file, free, inactive, pinned, shared, wired, used, pused, available
zabbix_get.exe -s 192.168.1.20 -p 10050 -k vm.memory.size[free]
598949888 // 监控内存变化

监控网卡

net.if.in [if,<mode>]       #网卡入口流量
net.if.out [if,<mode>] #网卡出口流量
net.if.total [if,<mode>] #网卡进/出流量总和 -if 网卡名称
-mode 可用值(如下) bytes 字节数
packets 包数量
errors 错误数量
droppend 丢包数量 [root@localhost ~]# zabbix_get -s 192.168.1.25 -k net.if.in[ens32,bytes]
165983
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k net.if.in[ens32,packets]
2166
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k net.if.out[ens32,packets]
2067
[root@localhost ~]# zabbix_get.exe -s 192.168.1.20 -p 10050 -k net.if.discovery
[{"{#IFNAME}":"ens32"},{"{#IFNAME}":"lo"}] // 列出系统网卡信息
zabbix_get.exe -s 192.168.1.20 -p 10050 -k net.if.total[ens32]
20785083 // 列出网卡总流量 zabbix_get.exe -s 192.168.1.20 -p 10050 -k net.tcp.listen[10050]
1 // 检测指定端口是否开启 zabbix_get.exe -s 192.168.1.20 -p 10050 -k net.tcp.port[,80]
0 // 检测本机web服务是否开启 zabbix_get.exe -s 192.168.1.20 -p 10050 -k net.tcp.service[ssh,,22]
1 // 检测是定服务是否在运行

监控IO/读写

vfs.dev.read [<device>,<type>,<mode>]    #磁盘读取
vfs.dev.write [<device>,<type>,<mode>] #磁盘写入 -device 磁盘设备(默认all)
-type sectors,operations,bytes,sps,ops,hps
-mode 默认有(avg1,avg5,avg15) [root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.read[/dev/sda,,avg1]
0.000000
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.read[all]
195.200000
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.read[all,,avg1]
195.200000
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.read[all,,avg5]
177.758242
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.write[all,,avg5]
465.284483
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.write[all,,avg1]
877.200000
[root@localhost ~]# zabbix_get -s 192.168.1.25 -k vfs.dev.write[/dev/sda,,]
374.800000

文件操作:

zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.file.exists[/etc/passwd]
1 // 检测指定文件是否存在 zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.file.md5sum[/etc/passwd]
52f5db4f5688b79b9c07ef5a42ea29af // md5验证 zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.file.size[/etc/passwd]
870 // 文件大小字节数 zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.file.time[/etc/passwd]
1578566854 // 文件日期时间戳 zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.fs.discovery // 列出文件系统所有目录结构
[{"{#FSNAME}":"/","{#FSTYPE}":"rootfs"},{"{#FSNAME}":"/sys","{#FSTYPE}":"sysfs"},{"{#FSNAME}":"/proc","{#FSTYPE}":"proc"},{"{#FSNAME}":"/dev","{#FSTYPE}":"devtmpfs"},{"{#FSNAME}":"/sys/kernel/security","{#FSTYPE}":"securityfs"},{"{#FSNAME}":"/dev/shm"}] mode - total (默认), free, used, pfree (空闲百分比), pused (使用百分比)
zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.fs.inode[/dev,free]
122355 // 检测/dev/空闲空间 zabbix_get.exe -s 192.168.1.20 -p 10050 -k vfs.fs.size[/dev,free]
502525952 // 磁盘空间,返回本地文件系统的使用量字节

## 监控web页状态

首先在被控主机安装httpd服务,并设置好一个页面.

[root@localhost ~]# yum install -y httpd
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
Package httpd-2.4.6-88.el7.centos.x86_64 already installed and latest version
Nothing to do [root@localhost ~]# echo "hello world" > /var/www/html/index.html
[root@localhost ~]# systemctl restart httpd

监控主机选择 主机->web场景->创建web场景->步骤->网页状态.

此时,配置web监控就完成啦,很简单吧,下面继续来看一下自定义key的使用步骤吧.

自定义一个Key

1.下面我们来自定义一个Key来实现监控两个服务,这里我们先写一个脚本,脚本有一个参数当传入http时,返回http的进程数量,当传入system参数时,显示系统的总进程数,此处实在客户端操作的.

#!/bin/bash

num=$1

if [ $num == "http" ]
then
ps aux |grep -v "grep" |grep "http" |wc -l
fi
if [ $num == "system" ]
then
ps aux |wc -l
fi [root@localhost ~]# chmod 777 -R shell.sh
[root@localhost ~]# bash shell.sh http
7
[root@localhost ~]# bash shell.sh system
192

2.将我们的脚本放入自定义目录,并设置zabbix添加一个key.

[root@localhost ~]# cp -a shell.sh  /etc/shell.sh
[root@localhost ~]# vim /etc/zabbix/zabbix_agentd.conf UnsafeUserParameters=1
UserParameter=shell.shell[*],/etc/shell.sh \$1 [root@localhost ~]# systemctl restart zabbix-agent

3.在zabbix服务端通过zabbix-get命令测试一下效果.

[root@localhost ~]# zabbix_get -s 192.168.1.25 -k shell.shell[http]
7 [root@localhost ~]# zabbix_get -s 192.168.1.25 -k shell.shell[system]
192

4.去web页面配置一下就可以了,很简单吧

主机->监控项->创建监控项

主机->图形->创建图形

最新文章

  1. Django URL name详解
  2. EXCEL快速自动填充方法集锦
  3. 去掉iPhone、iPad的默认按钮样式 去掉高光样式:
  4. Python之禅+八荣八耻
  5. [CentOs7]iptables防火墙安装与设置
  6. C++之路进阶——bzoj1468(tree)
  7. 使GridView可以单行横向滑动
  8. golang windows程序获取管理员权限(UAC ) via gocn
  9. c#使用XSLT将xml文档转换为html文档
  10. Socket 死连接详解
  11. 小试牛刀——python接口测试小框架
  12. Linux(CentOS)搭建SVN服务器全攻略
  13. openstack 安装
  14. BZOJ 3648: 寝室管理( 点分治 + 树状数组 )
  15. HomeBrew 安装 PHP7.1(开发笔记)
  16. Visual Studio Code 中编写 C++ 的工作流
  17. Reflect(反射)
  18. Springboot 系列(七)Spring Boot web 开发之异常错误处理机制剖析
  19. python 利用matplotlib中imshow()函数绘图
  20. 弹出层-layui

热门文章

  1. $\LaTeX$数学公式大全4
  2. fatal error C1189: #error: &quot;Oops: min() and/or max() are defined as preprocessor macros. Define NOMINMAX macro before including any system headers!&quot;
  3. Runtime Error R6034 Application has attempt to load the C runtime library incorrectly
  4. spark streaming 与 storm的对比
  5. 创建DevExtreme应用程序
  6. Struts2.3+Spring3.2+Hibernate4.2框架搭建
  7. n个骰子可能的点数和
  8. LC 272. Closest Binary Search Tree Value II 【lock,hard】
  9. python - 注释说明
  10. Struts2常量_Action配置路径_通配符