1. zabbix介绍
zabbix
是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
zabbix
能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
zabbix
由2部分构成,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)等配合使用。
2. zabbix特点
zabbix的主要特点:
- 安装与配置简单,学习成本低
- 支持多语言(包括中文)
- 免费开源
- 自动发现服务器与网络设备
- 分布式监视以及WEB集中管理功能
- 可以无agent监视
- 用户安全认证和柔软的授权方式
- 通过WEB界面设置或查看监视结果
- email等通知功能
Zabbix主要功能:
- CPU负荷
- 内存使用
- 磁盘使用
- 网络状况
- 端口监视
- 日志监视
3. 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 | 设置客户端日志文件存放路径 |
4. 部署zabbix
环境说明:
lamp: 192.168.157.133
因为zabbix
是用php
语言开发的,所以必须先部署lamp
架构,使其能够支持运行php
网页
[root@lamp ~]# yum -y install net-snmp-devel libevent-devel libxml2 libxml2-devel curl-devel //下载zaabix wget https://nchc.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/5.2.6/zabbix-5.2.6.tar.gz [root@lamp src]# ls debug kernels zabbix-5.2.6.tar.gz [root@lamp src]# tar xf zabbix-5.2.6.tar.gz [root@lamp src]# groupadd -r zabbix [root@lamp src]# useradd -r -g zabbix -M -s /sbin/nologin zabbix [root@lamp src]# mysql -uroot -p123456 mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 2 Server version: 5.7.31 MySQL Community Server (GPL) Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. 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.00 sec) mysql> grant all privileges on zabbix.* to zabbix@localhost identified by '123456'; Query OK, 0 rows affected, 2 warnings (0.00 sec) mysql> grant all privileges on zabbix.* to zabbix@192.168.157.133 identified by '123456'; mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) mysql> quit Bye [root@lamp src]# cd /usr/src/zabbix-5.2.6/database/mysql/ [root@lamp mysql]# ls data.sql double.sql images.sql Makefile.am Makefile.in schema.sql [root@lamp mysql]# mysql -uzabbix -p123456 zabbix < schema.sql mysql: [Warning] Using a password on the command line interface can be insecure. [root@lamp mysql]# mysql -uzabbix -p123456 zabbix < images.sql mysql: [Warning] Using a password on the command line interface can be insecure. [root@lamp mysql]# mysql -uzabbix -p123456 zabbix < data.sql mysql: [Warning] Using a password on the command line interface can be insecure. //编译安装zabbix [root@lamp zabbix-5.2.6]# pwd /usr/src/zabbix-5.2.6 [root@lamp zabbix-5.2.6]# ./configure --enable-server > --enable-agent > --with-mysql > --with-net-snmp > --with-libcurl > --with-libxml2 [root@lamp zabbix-5.2.6]# make install //修改服务端配置文件 //设置数据库信息 [root@lamp zabbix-5.2.6]# vim /usr/local/etc/zabbix_server.conf ### Option: DBPassword # Database password. # Comment this line if no password is used. # # Mandatory: no # Default: DBPassword=123456 #取消注释,设置zabbix数据库连接密码 [root@lamp zabbix-5.2.6]# zabbix_server [root@lamp zabbix-5.2.6]# zabbix_agentd [root@lamp zabbix-5.2.6]# ss -antl 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 0.0.0.0:9000 0.0.0.0:* LISTEN 0 128 [::]:22 [::]:* LISTEN 0 80 *:3306 *:* LISTEN 0 128 *:80 *:* //关闭防火墙和selinux [root@lamp zabbix-5.2.6]# systemctl stop firewalld [root@lamp zabbix-5.2.6]# setenforce 0 //修改/etc/php.ini的配置并重启php-fpm [root@lamp zabbix-5.2.6]# sed -ri 's/(post_max_size =).*/1 16M/g' /etc/php.ini [root@lamp zabbix-5.2.6]# sed -ri 's/(max_execution_time =).*/1 300/g' /etc/php.ini [root@lamp zabbix-5.2.6]# sed -ri 's/(max_input_time =).*/1 300/g' /etc/php.ini [root@lamp zabbix-5.2.6]# sed -i '/;date.timezone/a date.timezone = Asia/Shanghai' /etc/php.ini [root@lamp zabbix-5.2.6]# service php-fpm restart [root@lamp zabbix-5.2.6]# ls aclocal.m4 ChangeLog config.log configure.ac include Makefile misc sass AUTHORS compile config.status COPYING INSTALL Makefile.am missing src bin conf config.sub database install-sh Makefile.in NEWS ui build config.guess configure depcomp m4 man README [root@lamp zabbix-5.2.6]# cp -r ui/* /usr/local/apache/htdocs/zabbix/ [root@lamp zabbix-5.2.6]# chown -R apache.apache /usr/local/apache/htdocs //配置apache虚拟主机 [root@lamp zabbix-5.2.6]# vim /usr/local/apache/conf/extra/apache-vhosts.conf [root@lamp zabbix-5.2.6]# cat /usr/local/apache/conf/extra/apache-vhosts.conf <VirtualHost *:80> DocumentRoot "/usr/local/apache/htdocs/zabbix" ServerName www.thl.com ProxyRequests Off ProxyPassMatch ^/(.*.php)$ fcgi://0.0.0.0:9000/usr/local/apache/htdocs/zabbix/$1 <Directory "/usr/local/apache/htdocs/zabbix"> Options none AllowOverride none Require all granted </Directory> </VirtualHost> //使用浏览器访问本机IP即可。 //安装完成
4.4 登录zabbix
zabbix默认登录用户名和密码:
用户名 | 密码 |
---|---|
Admin | zabbix |
zabbix设置开机启动:
[root@lamp ~]# cd /usr/src/zabbix-5.2.6/misc/init.d/fedora/core5 [root@lamp core5]# ls zabbix_agentd zabbix_server [root@lamp core5]# cp -a zabbix_server /etc/init.d/ [root@lamp core5]# cp -a zabbix_agentd /etc/init.d/ [root@lamp core5]# chkconfig --add zabbix_server [root@lamp core5]# chkconfig zabbix_server on [root@lamp core5]# chkconfig --list|grep zabbix_server 注:该输出结果只显示 SysV 服务,并不包含 原生 systemd 服务。SysV 配置数据 可能被原生 systemd 配置覆盖。 要列出 systemd 服务,请执行 'systemctl list-unit-files'。 查看在具体 target 启用的服务请执行 'systemctl list-dependencies [target]'。 zabbix_server 0:关 1:关 2:开 3:开 4:开 5:开 6:关 [root@lamp core5]# chkconfig --add zabbix_agentd [root@lamp core5]# chkconfig zabbix_agentd on [root@lamp core5]# chkconfig --list|grep zabbix_agentd 注:该输出结果只显示 SysV 服务,并不包含 原生 systemd 服务。SysV 配置数据 可能被原生 systemd 配置覆盖。 要列出 systemd 服务,请执行 'systemctl list-unit-files'。 查看在具体 target 启用的服务请执行 'systemctl list-dependencies [target]'。 zabbix_agentd 0:关 1:关 2:开 3:开 4:开 5:开 6:关
[root@lamp ~]# reboot [root@lamp ~]# systemctl stop firewalld [root@lamp ~]# setenforce 0 [root@lamp ~]# ss -antl 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 0.0.0.0:9000 0.0.0.0:* LISTEN 0 128 [::]:22 [::]:* LISTEN 0 80 *:3306 *:* LISTEN 0 128 *:80 *:*