基于LAMP架构的zabbix服务搭建

监控服务zabbix部署

zabbix介绍

zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。

zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。

zabbix由2部分构成,zabbix server与可选组件zabbix agent

zabbix server可以通过SNMPzabbix agentping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在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 | 0}
UserParameter 指定自定义监控脚本参数
LogFile 设置客户端日志文件存放路径
部署zabbix

环境说明:

因为zabbix是用php语言开发的,所以必须先部署lamp架构,使其能够支持运行php网页

zabbix安装

下载依赖包
dnf -y install net-snmp-devel libevent-devel libxml2 libxml2-devel curl-devel
下载并解压zabbix软件包、创建zabbix用户
[root@C82 ~]# wget https://cdn.zabbix.com/zabbix/sources/stable/5.2/zabbix-5.2.6.tar.gz
[root@C82 ~]# tar xf zabbix-5.2.6.tar.gz 
[root@C82 ~]# useradd -r -M -s /sbin/nologin zabbix
配置zabbix数据库
[root@C82 ~]# ss -antl
State   Recv-Q  Send-Q   Local Address:Port   Peer Address:Port Process  
LISTEN  0       128            0.0.0.0:22          0.0.0.0:*             
LISTEN  0       128            0.0.0.0:9000        0.0.0.0:*             
LISTEN  0       80                   *:3306              *:*             
LISTEN  0       128                  *:80                *:*             
LISTEN  0       128               [::]:22             [::]:*             
[root@C82 ~]# mysql -uroot -pyzy123!
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.33 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.00 sec)

mysql> create user 'zabbix'@'localhost' identified by 'yzy123!';
Query OK, 0 rows affected (0.00 sec)

mysql> grant all privileges on zabbix.* to 'zabbix'@'localhost';
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> grant all on *.* to zabbix@'192.168.10.40' identified by 'yzy123!';
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

将数据导入数据库
[root@C82 ~]# cd zabbix-5.2.6/database/mysql/
[root@C82 mysql]# mysql -uzabbix -pyzy123! zabbix < schema.sql
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@C82 mysql]# mysql -uzabbix -pyzy123! zabbix < images.sql
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@C82 mysql]# mysql -uzabbix -pyzy123! zabbix < data.sql
mysql: [Warning] Using a password on the command line interface can be insecure.
编译安装zabbix
[root@C82 ~]# cd zabbix-5.2.6/
[root@C82 zabbix-5.2.6]# ./configure --enable-server \
--enable-agent \
--with-mysql \
--with-net-snmp \
--with-libcurl \
--with-libxml2

[root@C82 zabbix-5.2.6]# make install
配置zabbix_server.conf文件,取消注释并填写自己zabbix主机中mysql用户的密码
[root@C82 zabbix-5.2.6]# cd /usr/local/etc/
[root@C82 etc]# vim zabbix_server.conf
DBPassword=yzy123!		//vim进入后在118行填入自己的mysql密码
启动zabbix_server和zabbix_agentd
[root@C82 etc]# zabbix_server
[root@C82 etc]# zabbix_agentd
[root@C82 etc]# ss -antl
State   Recv-Q  Send-Q   Local Address:Port    Peer Address:Port Process 
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       80                   *:3306               *:*            
LISTEN  0       128                  *:80                 *:*            
LISTEN  0       128               [::]:22              [::]:*  
将原网站根目录改名为zabbix,将ui目录下的程序复制到zabbix的根目录下并设置属主和属组
[root@C82 etc]# mv /usr/local/apache/htdocs/yzy /usr/local/apache/htdocs/zabbix
[root@C82 zabbix]# rm -rf *
[root@C82 etc]# cp -r /root/zabbix-5.2.6/ui/* /usr/local/apache/htdocs/zabbix/
[root@C82 zabbix]# chown -R apache.apache /usr/local/apache/htdocs
配置虚拟主机并且重启apache服务
[root@C82 zabbix]# vim /etc/httpd24/extra/httpd-vhosts.conf

    DocumentRoot "/usr/local/apache/htdocs/zabbix"
    ServerName www.yzy.com
    ProxyRequests Off
    ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/usr/local/apache/htdocs/zabbix/$1
    
        Options none
        AllowOverride none
        Require all granted
    


[root@C82 zabbix]# /usr/local/apache/bin/apachectl restart
修改etc/php.ini 的配置并重启php服务
[root@C82 zabbix]# sed -ri 's/(post_max_size =).*/\1 16M/g' /etc/php.ini
[root@C82 zabbix]# sed -ri 's/(max_execution_time =).*/\1 300/g' /etc/php.ini
[root@C82 zabbix]# sed -ri 's/(max_input_time =).*/\1 300/g' /etc/php.ini
[root@C82 zabbix]# sed -i '/;date.timezone/a date.timezone = Asia/Shanghai' /etc/php.ini
[root@C82 zabbix]# service php-fpm restart
修改/usr/local/apache/htdocs/zabbix/conf的权限为777,使它能够自动生成数据库文件
[root@C82 zabbix]# chmod 777 /usr/local/apache/htdocs/zabbix/conf
关闭防火墙和selinux
[root@C82 zabbix]# systemctl stop firewalld
[root@C82 zabbix]# setenforce 0
在192.168.10.40网站上初始化zabbix

基于LAMP架构的zabbix服务搭建_第1张图片
基于LAMP架构的zabbix服务搭建_第2张图片
基于LAMP架构的zabbix服务搭建_第3张图片
基于LAMP架构的zabbix服务搭建_第4张图片
基于LAMP架构的zabbix服务搭建_第5张图片
基于LAMP架构的zabbix服务搭建_第6张图片
基于LAMP架构的zabbix服务搭建_第7张图片
基于LAMP架构的zabbix服务搭建_第8张图片
基于LAMP架构的zabbix服务搭建_第9张图片

看到上图就说明初始化成功了
修改/usr/local/apache/htdocs/zabbix/conf的权限为755,不让它可以自动写文件。(卸磨杀驴)
[root@C82 zabbix]# chmod 755 /usr/local/apache/htdocs/zabbix/conf

你可能感兴趣的:(zabbix,lamp,linux,apache)