zabbix定义
zabbix(音同 zæbix)是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
zabbix由2部分构成,zabbix server与可选组件zabbix agent。
zabbix server可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux,Solaris,HP-UX,AIX,Free BSD,Open BSD,OS X等平台上。
zabbix的主要特点:
- 安装与配置简单,学习成本低 - 支持多语言(包括中文) - 免费开源 - 自动发现服务器与网络设备 - 分布式监视以及WEB集中管理功能 - 可以无agent监视 - 用户安全认证和柔软的授权方式 - 通过WEB界面设置或查看监视结果 - email等通知功能
Zabbix主要功能:
- CPU负荷 - 内存使用 - 磁盘使用 - 网络状况 - 端口监视 - 日志监视
Zabbix的系统组成:
Zabbix Server:负责接收Agent发送的报告信息,组织所有配置、数据和操作。
Database Storage:存储配置信息以及收集到的数据。
Web Interface:Zabbix的GUI 接口,通常与Server运行在同一台机器上。
Proxy:可选组件,常用于分布式监控环境中。
Agent:部署在被监控主机上,负责收集数据发送给Server。
1.1 Zabbix运行条件:
Server:Zabbix-Server需运行在LAMP(Linux+Apache+Mysql+PHP)环境下,对硬件要求低。
Agent:目前已有的agent基本支持市面常见的OS,包含Linux、HPUX、Solaris、Sun、windows。
SNMP:支持各类常见的网络设备
1.2 Zabbix功能
具备常见的商业监控软件所具备的功能(主机的性能监控、网络设备性能监控、数据库性能监控、FTP等通用协议监控、多种告警方式、详细的报表图表绘制) 支持自动发现网络设备和服务器;支持分布式,能集中展示、管理分布式的监控点;扩展性强,server提供通用接口,可以自己开发完善各类监控。
默认的用户名为 admin,密码是zabbix
使用 zabbix 进行监控之前,要理解zabbix监控的流程。
一次完整的监控流程可以简单描述为:
Host-Groups(设备组)->Hosts(设备)->Applications(监控项组)->Items(监控项)->
Triggers(触发器)->Actions(告警动作)->Medias(告警方式)->User Groups(用户组)->
Users(用户)
1.Server
zabbix系统核心进程,轮询并捕获数据、发送通知等。是zabbix agent和zabbix proxy汇报数据的对象。server自身可远程检测网络服务。所有的前后端配置、统计信息、可操作数据存储于此。包含server、前段界面和后端DB几部分。
2.Agent
部署在被监控主机上用于监控本地资源和应用并向zabbix-server汇报结果。使用本地系统调用故非常高效。
有主动和被动两种检测模式。被动模式下agent根据server或proxy的具体请求来返回数据。主动模式下先主动由server获取监控项列表再检测并返回新的数据。采用主动或被动检测取决于相应监控项的配置。angentd 的作用就是获取 host 数据,然后将收集到的数据发送给 server(主动模式)。或者是server 主动来拿取数据(被动模式)。
3.Proxy
可以自由选择部署或者不部署,主要用于分担server的负载。在集中化监控远程位置、分支、网络的场景中是很好的解决方案。可从被监控设备收集数据缓存在proxy本地后传递给其所属的zabbix server。proxy需要单独的数据库。
一.封装虚拟机
封装企业7.3虚拟机
以企业7.0虚拟机安装方式安装,注意不安装图形界面
选择最小化安装
封装时参考企业6.5封装,注意:
修改网卡类型 、修改ip 主机解析 、 关闭防火墙开机自启动 、yum源 、主机名、关闭selinux
企业6.5虚拟机安装及封装
企业7.0虚拟机安装
二.安装zabbix监控
1.安装zabbix监控所需软件
yum install -y
zabbix-web-3.4.6-1.el7.noarch.rpm # Zabbix前端界面
zabbix-web-mysql-3.4.6-1.el7.noarch.rpm # zabbix数据库
zabbix-server-mysql-3.4.6-1.el7.x86_64.rpm # Zabbix服务器
fping-3.10-1.el7.x86_64.rpm
iksemel-1.4-2.el7.centos.x86_64.rpm
php-bcmath-5.4.16-42.el7.x86_64.rpm
php-mbstring-5.4.16-42.el7.x86_64.rpm # 这两个安装包一定要和自己系统中的php版本保持一致
2.安装mariadb数据库,打开并做初始化
[root@server1 zabbix]# yum install -y mariadb-server
[root@server1 zabbix]# systemctl start mariadb
[root@server1 zabbix]# mysql_secure_installation
Set root password? [Y/n] y
New password:
Re-enter new password:
Remove anonymous users? [Y/n] y
... Success!
Disallow root login remotely? [Y/n] y
... Success!
Remove test database and access to it? [Y/n] y
- Dropping test database...
... Success!
- Removing privileges on test database...
... Success!
Reload privilege tables now? [Y/n] y
... Success!
Cleaning up...
Thanks for using MariaDB!
3.进入到数据库中使用utf-8编码并对用户授权
MariaDB [(none)]> create database zabbix character set utf8 collate utf8_bin;
Query OK, 1 row affected (0.00 sec) # 使用utf编码
MariaDB [(none)]> grant all privileges on zabbix.* to zabbix@localhost identified by 'westos';
4.导入zabbix数据库
[root@server1 zabbix]# cd /usr/share/doc/zabbix-server-mysql-3.4.6/
[root@server1 zabbix-server-mysql-3.4.6]# ls
AUTHORS ChangeLog COPYING create.sql.gz NEWS README
[root@server1 zabbix-server-mysql-3.4.6]# zcat create.sql.gz |mysql -u zabbix -p zabbix
Enter password:
[root@server1 zabbix-server-mysql-3.4.6]# mysql -p
Enter password:
MariaDB [(none)]> use zabbix
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
MariaDB [zabbix]> show tables;
5.编辑zabbix的配置文件
[root@server1 zabbix-server-mysql-3.4.6]# cd /etc/zabbix/
[root@server1 zabbix]# vim zabbix_server.conf #修改数据库密码,数据库套接字
125 DBPassword=westos
132 DBSocket=/var/lib/mysql/mysql.sock
[root@server1 zabbix]# cd /etc/httpd/conf.d/
[root@server1 conf.d]# ls
autoindex.conf README welcome.conf
php.conf userdir.conf zabbix.conf
[root@server1 conf.d]# vim zabbix.conf
19 php_value date.timezone Asia/Shanghai
6.安装监控的软件zabbix agent:
zabbix agent需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU等信息的收集。
yum install -y zabbix-agent-3.4.6-1.el7.x86_64.rpm
systemctl start zabbix-agent
7.打开服务zabbix监控服务
[root@server11 conf.d]# systemctl restart zabbix-server zabbix-agent httpd
[root@server11 conf.d]# systemctl enable zabbix-server zabbix-agent httpd
8.在浏览器中输入172.25.8.1/zabbix进行zabbix的web界面配置
(1)进入zabbix界面
(2)将zabbix与数据库连接,密码是设置的mariadb数据库密码
(3)登陆zabbix监控平台,密码是导入zabbix数据库时导入的密码(Zabbixserver)
(4)成功登陆zabbix监控平台
注意:初始帐号密码
帐号:Admin
密码:zabbix
(5)进入zabbix平台后,可以修改监控语言和登陆密码(点击右上方的人头标志,开始修改密码和语言)
三.利用zabbix监控平台监控server2(企业6.5)主机
1.在server2上下载安装zabbix-agent
[root@server2 ~]# rpm -ivh zabbix-agent-3.4.6-1.el6.x86_64.rpm
2.配置zabbix agent
[root@server2 ~]# vim /etc/zabbix/zabbix_agentd.conf
97 Server=172.25.8.1 # zabbix主机
138 ServerActive=172.25.8.1
149 Hostname=server2 # 可以被zabbix主机主动发现的主机名
[root@server12 ~]# /etc/init.d/zabbix-agent start
查看日志报错:
[root@server2 zabbix]# tail -f /var/log/messages
四、在服务器端(zabbix web )添加监控
第一种:创建主机
配置—>主机—>创建主机—>模板—>更新
刷新网页(需要等待)
刷新页面(需要等待)
第二种:自动发现
配置–>自动发现–>创建发现规则
填写如下,主要时ip范围和检查项(zabbix),完成后添加启用
配置–>动作–>事件源–>自动发现–>创建动作
第三种:自动注册
配置如下:配置–>动作–>事件源–>自动注册–>创建动作
五、zabbix使用api添加监控删除监控
什么是API:
API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。简单的说,API就是对外的接口,利用API可以直接到达软件硬件内部来进行操作….
zabbix中API的作用:
Zabbix API为批量操作、第三方软件集成以及其他作用提供可编程接口。
API的大致工作流如下:
(1)API 采用JSON-RPC实现。这意味着调用任何函数,都需要发送POST请求,输入输出数据都是以JSON格式
(2)准备JSON对象,它描述了你想要做什么(创建主机,获取图像,更新监控项等)。
(3)获取JSON格式响应。
1.查看zabbix监控系统的api接口:
[root@server1 ~]# vim zabbix-api.sh
curl -s -X POST -H 'Content-Type:application/json' -d '
# 利用curl命令模拟json格式的post请求
{
"jsonrpc": "2.0", # 这是标准的JSON RPC参数以标示协议版本。所有的请求都会保持不变
"method": "user.login", # 利用用户登陆的方式获取API
"params": {
"user": "Admin",
"password": "westos" # zabbix监控系统的用户名和密码
},
"id": 1, # 这个字段用于绑定JSON请求和响应。响应会跟请求有相同的"id"。在一次性发送多个请求时很有用,这些也不需要唯一或者连续
"auth": null
}' http://172.25.8.1/zabbix/api_jsonrpc.php | python -m json.tool
# 采用POST方法向http://example.com/zabbix/api_jsonrpc.php发送此JSON对象. http://example.com/zabbix/是Zabbix前端地址。
# api_jsonrpc.php是调用API的PHP脚本。可在安装可视化前端的目录下找到。
[root@server1 ~]# chmod +x zabbix-api.sh
[root@server1 ~]# ./zabbix-api.sh
2.查看zabbix主机和被监控主机信息
curl -X POST -H 'Content-Type:application/json' -d '
{
"jsonrpc": "2.0",
"method": "host.get", # host.get方法
"params": {
"output": ["host"]
},
"auth": "b02a6316fc2e2bb5315b0871092c740b", # zabbix监控的API
"id": 1
}' http://172.25.8.1/zabbix/api_jsonrpc.php | python -m json.tool
3.删除zabbix监控中的主机
curl -s -X POST -H 'Content-Type:application/json' -d '
{
"jsonrpc": "2.0",
"method": "host.delete", # 调用host.delete方法
"params": [
"10254" # 上一步返回的被监控主机host号
],
"auth": "b02a6316fc2e2bb5315b0871092c740b",
"id": 1
}' http://172.25.8.1/zabbix/api_jsonrpc.php | python -m json.tool
server2已删除
4.在zabbix监控中创建被监控主机
curl -X POST -H 'Content-Type:application/json' -d '
{
"jsonrpc": "2.0",
"method": "host.create", # 调用host.create方法
"params": {
"host": "server2", # 被监控的主机名
"interfaces": [
{
"type": 1,
"main": 1,
"useip": 1,
"ip": "172.25.8.2", # 被监控主机的ip
"dns": "",
"port": "10254" # zabbix-agent的端口号
}
],
"groups": [
{
"groupid": "2" # 建立的主机加入的群组
# 怎样获知groupid和templateid呢?我们可以在zabbix的web界面中打开某个群组和模版,即可在上边的地址栏中得到......
}
],
"templates": [
{
"templateid": "10001" # 建立的主机使用的模版
}
]
},
"auth": "b02a6316fc2e2bb5315b0871092c740b",
"id": 1
}' http://172.25.8.1/zabbix/api_jsonrpc.php | python -m json.tool
这时在zabbix的web界面查看,server2主机已经出现
注意:
在复制粘贴时记得删除后面的注释,否则会运行错误!