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)等配合使用。
zabbix特点
zabbix的主要特点:
- 安装与配置简单,学习成本低
- 支持多语言(包括中文)
- 免费开源
- 自动发现服务器与网络设备
- 分布式监视以及WEB集中管理功能
- 可以无agent监视
- 用户安全认证和柔软的授权方式
- 通过WEB界面设置或查看监视结果
- email等通知功能
Zabbix主要功能:
- CPU负荷
- 内存使用
- 磁盘使用
- 网络状况
- 端口监视
- 日志监视
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 |
UserParameter | 指定自定义监控脚本参数 |
LogFile | 设置客户端日志文件存放路径 |
部署zabbix
环境说明:
环境 | IP | 要安装的应用 |
---|---|---|
服务端 | 192.168.159.3 | lamp架构 |
客户端 | 192.168.159.5 | zabbix agent |
因为zabbix是用php语言开发的,所以必须先部署lamp架构,使其能够支持运行php网页
LAMP架构步骤省略
zabbix服务端安装与配置
[root@service ~]# tar xf zabbix-5.4.4.tar.gz -C /usr/local/src
[root@service ~]# useradd -r -M -s /sbin/nolong zabbix
[root@service ~]# mysql -uroot -p1
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 8
Server version: 10.3.17-MariaDB MariaDB Server
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
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.621 sec)
mysql > grant all privileges on zabbix.* to zabbix@localhost identified by '1';
Query OK, 0 rows affected (2.154 sec)
mysql > flush privileges;
Query OK, 0 rows affected (2.496 sec)
[root@service ~]# cd /usr/local/src/zabbix-5.4.4/database/mysql/
[root@service mysql]# mysql -uzabbix -p1 zabbix < schema.sql
[root@service mysql]# mysql -uzabbix -p1 zabbix < images.sql
[root@service mysql]# mysql -uzabbix -p1 zabbix < data.sql
[root@service ~]# cd /usr/local/src/zabbix-5.4.4/
[root@service 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@service zabbix-5.4.4]# make install
[root@service zabbix-5.4.4]# ls /usr/local/etc/
zabbix_agentd.conf zabbix_server.conf
zabbix_agentd.conf.d zabbix_server.conf.d
//修改服务端配置文件
//设置数据库信息
[root@service ~]# vim /usr/local/etc/zabbix_server.conf
DBPassword=1
[root@service ~]# mkdir /var/lib/mysql
[root@service ~]# ln -s /tmp/mysql.sock /var/lib/mysql/
[root@service ~]# zabbix_server
[root@service ~]# zabbix_agentd
[root@service ~]# ss -antl
State Recv-Q Send-Q Local Address:Port Peer Address:Port
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 0.0.0.0:111 0.0.0.0:*
LISTEN 0 32 192.168.122.1:53 0.0.0.0:*
LISTEN 0 128 0.0.0.0:22 0.0.0.0:*
LISTEN 0 5 127.0.0.1:631 0.0.0.0:*
LISTEN 0 80 *:3306 *:*
LISTEN 0 128 [::]:111 [::]:*
LISTEN 0 128 *:80 *:*
LISTEN 0 128 [::]:22 [::]:*
LISTEN 0 5 [::1]:631 [::]:*
web界面配置与安装
[root@service ~]# sed -ri 's/(post_max_size =).*/\1 16M/g' /etc/php.ini
[root@service ~]# sed -ri 's/(max_execution_time =).*/\1 300/g' /etc/php.ini
[root@service ~]# sed -ri 's/(max_input_time =).*/\1 300/g' /etc/php.ini
[root@service ~]# sed -i '/;date.timezone/a date.timezone = Asia/Shanghai' /etc/php.ini
[root@service ~]# service php-fpm restart
Gracefully shutting down php-fpm . done
Starting php-fpm done
[root@service ~]# cd /usr/local/src/zabbix-5.4.4/
[root@service zabbix-5.4.4]# ls
aclocal.m4 conf configure.ac install-sh misc ui
AUTHORS config.guess COPYING m4 missing
bin config.log database Makefile NEWS
build config.status depcomp Makefile.am README
ChangeLog config.sub include Makefile.in sass
compile configure INSTALL man src
[root@service zabbix-5.4.4]# mkdir /usr/local/httpd/htdocs/zabbix
[root@service zabbix-5.4.4]# cp ui/* /usr/local/httpd/htdocs/zabbix/ -r
[root@service zabbix-5.4.4]# chown -R apache.apache /usr/local/httpd/htdocs
[root@service ~]# vim /usr/local/httpd/conf/httpd.conf
//在配置文件的末尾加如下内容
<VirtualHost *:80>
DocumentRoot "/usr/local/apache/htdocs/zabbix"
ServerName zabbix.weixiaoya.com
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/usr/local/httpd/htdocs/zabbix/$1
<Directory "/usr/local/httpd/htdocs/zabbix">
Options none
AllowOverride none
Require all granted
</Directory>
</VirtualHost>
//设置zabbix/conf目录的权限,让zabbix有权限生成配置文件zabbix.conf.php
[root@service ~]# chmod 777 /usr/local/httpd/htdocs/zabbix/conf
[root@service ~]# ll -d /usr/local/httpd/htdocs/zabbix/conf
drwxrwxrwx 3 apache apache 94 9月 27 07:13 /usr/local/httpd/htdocs/zabbix/conf
//重启apache
[root@service ~]# apachectl -t
Syntax OK
[root@service ~]# apachectl stop
[root@service ~]# apachectl start
[root@service ~]# ss -antl
State Recv-Q Send-Q Local Address:Port Peer Address:Port
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 80 0.0.0.0:3306 0.0.0.0:*
LISTEN 0 128 0.0.0.0:111 0.0.0.0:*
LISTEN 0 32 192.168.122.1:53 0.0.0.0:*
LISTEN 0 128 0.0.0.0:22 0.0.0.0:*
LISTEN 0 5 127.0.0.1:631 0.0.0.0:*
LISTEN 0 128 [::]:111 [::]:*
LISTEN 0 128 *:80 *:*
LISTEN 0 128 [::]:22 [::]:*
LISTEN 0 5 [::1]:631 [::]:*
[root@service ~]# vim /usr/lib/systemd/system/httpd.service
[root@service ~]# cat /usr/lib/systemd/system/httpd.service
t]
Description=Httpd server daemon
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/apache/bin/apachectl start
ExecStop=/usr/local/apache/bin/apachectl stop
ExecReload=/bin/kill -HUP $MAINPID
[Install]
WantedBy=multi-user.target
[root@service ~]# systemctl daemon-reload
[root@service ~]# systemctl enable --now httpd.service
Created symlink /etc/systemd/system/multi-user.target.wants/httpd.service → /usr/lib/systemd/system/httpd.service.
[root@service ~]# vim /opt/start.sh
[root@service ~]# cat /opt/start.sh
#!/bin/bash
service mysqld start
service php-fpm start
zabbix_server
zabbix_agentd
[root@service ~]# chmod +x /opt/start.sh
[root@service ~]# vim /etc/rc.d/rc.local
[root@service ~]# cat /etc/rc.d/rc.local
#!/bin/bash
# THIS FILE IS ADDED FOR COMPATIBILITY PURPOSES
#
# It is highly advisable to create own systemd services or udev rules
# to run scripts during boot instead of using this file.
#
# In contrast to previous versions due to parallel execution during boot
# this script will NOT be run after all other services.
#
# Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
# that this script will be executed during boot.
touch /var/lock/subsys/local
sourece /opt/start.sh
评论区