Zabbix介绍
- zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案,zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
- zabbix由zabbix server与可选组件zabbix agent 构成。
- zabbix server可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux,Ubuntu,Solaris,HP-UX,AIX,Free BSD,Open BSD,OS X等平台上。
- zabbix agent需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU等信息的收集。
- zabbix server可以单独监视远程服务器的服务状态;同时也可以与zabbix agent配合,可以轮询zabbix agent主动接收监视数据(agent方式),同时还可被动接收zabbix agent发送的数据(trapping方式)。另外zabbix server还支持SNMP (v1,v2),可以与SNMP软件(例如:net-snmp)等配合使用。
- 监控服务除了Zabbix外,还有其他的监控服务,如:
- Cacti:Cacti是一套基于PHP、MySQL、SNMP及RRDTool开发的网络流量监测图形分析工具。
- Nagios:Nagios是一款开源的免费网络监视工具,能有效监控Windows、Linux和Unix的主机状态,交换机路由器等网络设备,打印机等。在系统或服务状态异常时发出邮件或短信报警第一时间通知网站运维人员,在状态恢复后发出正常的邮件或短信通知,配置较为复杂。
- prometheus:Prometheus 是一个开源的服务监控系统和时间序列数据库。
- zabbuix+Grafana
Zabbix集合了Cacti和Nagios的优点
Zabbix的特点
zabbix的主要特点:
- 安装与配置简单
- 免费开源
- 自动发现服务器与网络设备
- 分布式监视以及WEB集中管理功能
- 可以无agent(代理)监视
- 用户安全认证和柔软的授权方式
- 通过WEB界面设置或查看监视结果
- Email等通知功能
系统Zabbix主要功能:
- CPU负荷
- 内存使用
- 磁盘使用
- 网络状况
- 端口监视
- 日志监视
Zabbix的监控指标:
监控 | / |
---|---|
系统监控 | 内存的使用率 CPU的使用率 磁盘的使用率 监控文件是否被修改 |
网络监控 | 网卡 网络设备(路由器 交换机) |
业务监控 | 进程 端口号 日志 |
硬件监控<IPMI传感器> | 数量 温度 电源 |
zabbix配置文件
zabbix配置文件有两种:
- 服务器端配置文件(/usr/local/etc/zabbix_server.conf)
- 客户端配置文件(/usr/local/etc/zabbix_agentd.conf)
- zabbix代理配置文件(/usr/local/etc/zabbix_proxy.conf)
服务器端配置文件zabbix_server.conf常用配置参数:
参数 | 作用 |
---|---|
LogFile | 设置服务端日志文件存放路径 |
ListenIP | 设置服务端监听IP |
ListenPort | 设置服务端监听的端口号 |
PidFile | 设置服务端进程号文件存放路径 |
DBHost | 指定zabbix的数据库服务器IP |
DBName | 指定zabbix使用的数据库库名 |
DBUser | 指定zabbix数据库登录用户 |
DBPassword | 指定zabbix数据库登录密码 |
DBPort | 指定zabbix数据库端口号 |
User | 设置zabbix以什么用户的身份运行 |
AlertScriptsPath | 设置告警脚本存放路径 |
ExternalScripts | 外部脚本存放路径 |
客户端配置文件zabbix_agentd.conf常用配置参数:
参数 | 作用 |
---|---|
Server | 指定zabbix服务器的IP或域名 |
ServerActive | 指定zabbix服务器的IP或域名 |
Hostname | 指定本机的主机名,此项必须与web界面配置项一致 |
UnsafeUserParameters | 是否启用自定义监控项,可选值为{1 | 0} |
UserParameter | 指定自定义监控脚本参数 |
LogFile | 设置客户端日志文件存放路径 |
部署zabbix
环境说明:
环境 | IP | 要安装的应用 |
---|---|---|
服务器 | 192.168.129.250 | lamp架构 zabbix server zabbix agent |
因为zabbix
是用php
语言开发的,所以必须先部署lamp
架构,使其能够支持运行php
网页
要求:
Software | Version | Comments |
---|---|---|
MySQL | 5.7.28-8.0.X | \ |
MariaDB | 10.0.37-10.6.X | \ |
Apache | 1.3.12 or later | \ |
PHP | 7.2.5 or later | PHP 8.0 is not supported. |
安装lamp
[root@Server ~]# httpd -v
Server version: Apache/2.4.49 (Unix)
Server built: Sep 27 2021 09:42:08
[root@Server ~]# mysql -V
mysql Ver 14.14 Distrib 5.7.34, for linux-glibc2.12 (x86_64) using EditLine wrapper
[root@Server ~]# ss -anlit
LISTEN 0 128 127.0.0.1:9000 0.0.0.0:*
cubic cwnd:10
LISTEN 0 128 *:80 *:*
cubic cwnd:10
LISTEN 0 80 *:3306 *:*
cubic cwnd:10
zabbix服务端安装
//安装依赖包
[root@Server ~]# yum -y install net-snmp-devel libevent-devel
//下载Zabbix
[root@Server ~]# cd /usr/src/
[root@Server src]# wget https://cdn.zabbix.com/zabbix/sources/stable/5.4/zabbix-5.4.4.tar.gz
//解压
[root@Server src]# tar -xf zabbix-5.4.4.tar.gz
//创建zabbix用户和组
[root@Server src]# useradd -r -M -s /sbin/nologin zabbix
//配置Zabbix数据库
[root@Server ~]# mysql -uroot -p123456
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.35 MySQL Community Server (GPL)
Copyright (c) 2000, 2021, Oracle and/or its affiliates.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> create database zabbix character set utf8 collate utf8_bin;
Query OK, 1 row affected (0.01 sec)
mysql> grant all privileges on zabbix.* to 'zabbix'@'localhost' identified by 'zabbix123!';
Query OK, 0 rows affected, 2 warnings (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql> quit
Bye
[root@Server ~]# cd /usr/src/zabbix-5.4.4/database/mysql/
[root@Server mysql]# ls
Makefile.am Makefile.in data.sql double.sql images.sql schema.sql
[root@Server mysql]# mysql -uzabbix -p'zabbix123!' zabbix < schema.sql
[root@Server mysql]# mysql -uzabbix -p'zabbix123!' zabbix < images.sql
[root@Server mysql]# mysql -uzabbix -p'zabbix123!' zabbix < data.sql
[root@Server ~]# mysql -uroot -p123456
mysql> use zabbix; //进入到zabbix库中
mysql> show tables;
+----------------------------+
| Tables_in_zabbix |
+----------------------------+
| acknowledges |
| actions |
| alerts |
| auditlog |
| auditlog_details |
......
166 rows in set (0.00 sec) //此时数据就全部导入进来了 166个表
//编译安装Zabbix
[root@Server ~]# cd /usr/src/zabbix-5.4.4
[root@Server zabbix-5.4.4]# ./configure --enable-server \
--enable-agent \
--with-mysql \
--with-net-snmp \
--with-libcurl \
--with-libxml2
······
LDAP support: no
IPv6 support: no
***********************************************************
* Now run 'make install' *
* *
* Thank you for using Zabbix! *
* <http://www.zabbix.com> *
***********************************************************
[root@Server zabbix-5.4.4]# make install
Zabbix服务端配置
[root@Server ~]# ls /usr/local/etc/
zabbix_agentd.conf zabbix_agentd.conf.d zabbix_server.conf zabbix_server.conf.d
//修改服务端配置文件
[root@Server ~]# vim /usr/local/etc/zabbix_server.conf
DBPassword=zabbix123! #取消这一行的注释(123行)并在后面加上zabbix数据库连接的密码
......
//启动zabbix_server和zabbix_agentd
[root@Server ~]# mkdir /var/lib/mysql
[root@Server ~]# ln -s /tmp/mysql.sock /var/lib/mysql/
[root@Server ~]# zabbix_server
[root@Server ~]# zabbix_agentd
[root@Server ~]# ss -anlt
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 128 0.0.0.0:22 0.0.0.0:*
LISTEN 0 128 0.0.0.0:10050 0.0.0.0:*
LISTEN 0 128 0.0.0.0:10051 0.0.0.0:*
LISTEN 0 128 127.0.0.1:9000 0.0.0.0:*
LISTEN 0 128 [::]:22 [::]:*
LISTEN 0 80 *:3306 *:*
LISTEN 0 128 *:80
Zabbix服务端web界面安装与配置
//修改/etc/php.ini的配置并重启php-fpm
[root@Server ~]# sed -ri 's/(post_max_size =).*/\1 16M/g' /etc/php.ini
[root@Server ~]# sed -ri 's/(max_execution_time =).*/\1 300/g' /etc/php.ini
[root@Server ~]# sed -ri 's/(max_input_time =).*/\1 300/g' /etc/php.ini
[root@Server ~]# sed -i '/;date.timezone/a date.timezone = Asia/Shanghai' /etc/php.ini
[root@Server ~]# systemctl restart php-fpm.service
//将Zabbix目录中的前端网页复制到php存放网页的目录
[root@Server ~]# cd /usr/src/zabbix-5.4.4/
[root@Server zabbix-5.4.4]# ls
AUTHORS Makefile README compile config.status database m4 sass
COPYING Makefile.am aclocal.m4 conf config.sub depcomp man src
ChangeLog Makefile.in bin config.guess configure include misc ui
INSTALL NEWS build config.log configure.ac install-sh missing
[root@Server zabbix-5.4.4]# mkdir /usr/local/apache/htdocs/zabbix
[root@Server zabbix-5.4.4]# cp -r ui/* /usr/local/apache/htdocs/zabbix/
[root@Server zabbix-5.4.4]# chown -R apache.apache /usr/local/apache/htdocs/
//配置apache虚拟主机
[root@Server ~]# vim /usr/local/apache/conf/httpd.conf #在配置文件中添加如下内容
<VirtualHost *:80>
DocumentRoot "/usr/local/apache/htdocs/zabbix"
ServerName www.hhr.com
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/usr/local/apache/htdocs/zabbix/
<Directory "/usr/local/apache/htdocs/zabbix">
Options none
AllowOverride none
Require all granted
</Directory>
</VirtualHost>
//关闭防火墙
[root@Server ~]# systemctl disable --now firewalld.service
[root@Server ~]# setenforce 0
//修改/usr/local/apache/htdocs/zabbix/conf的权限,这样才能自动生成数据库连接文件
[root@Server ~]# chmod 777 /usr/local/apache/htdocs/zabbix/conf
[root@Server ~]# ll -d /usr/local/apache/htdocs/zabbix/conf
drwxrwxrwx. 3 root root 94 Sep 26 22:22 /usr/local/apache/htdocs/zabbix/conf
//重启apache服务
[root@Server ~]# systemctl restart httpd.service
[root@Server ~]# ss -anltu
Netid State Recv-Q Send-Q Local Address:Port Peer Address:Port
tcp LISTEN 0 128 0.0.0.0:22 0.0.0.0:*
tcp LISTEN 0 128 0.0.0.0:10050 0.0.0.0:*
tcp LISTEN 0 128 0.0.0.0:10051 0.0.0.0:*
tcp LISTEN 0 128 127.0.0.1:9000 0.0.0.0:*
tcp LISTEN 0 128 *:80 *:*
tcp LISTEN 0 128 [::]:22 [::]:*
tcp LISTEN 0 80 *:3306 *:*
安装zabbix web界面
//恢复zabbix/conf目录的权限为755:
[root@Server ~]# chmod 755 /usr/local/apache/htdocs/zabbix/conf
[root@Server ~]# ll -d /usr/local/apache/htdocs/zabbix/conf
drwxr-xr-x. 3 root root 117 Sep 26 22:50 /usr/local/apache/htdocs/zabbix/conf
zabbix默认登录用户名和密码:
用户名 | 密码 |
---|---|
Admin | zabbix |