zabbix服务部署

文章目录

  • zabbix
    • 1 zabbix简介
      • 1.1 组成部件
      • 1.2 监控原理
      • 1.3 Zabbix 6.0新特性
      • 1.4 Zabbix6.0功能组件
        • 1.4.1 Zabbix Server
        • 1.4.2 数据库
        • 1.4.3 Web界面
        • 1.4.4 Zabbix Agent
        • 1.4.5 Zabbix Proxy
        • 1.4.6 Java Gateway
    • 2 部署zabbix服务端
      • 2.1 部署Nginx
      • 2.2 安装PHP
      • 2.3 修改Nginx配置
      • 2.4 修改PHP配置
      • 2.5 创建目录和测试文件
      • 2.6 部署Mariadb yum源
      • 2.7 初始化数据库
      • 2.8 编译安装zabbix server服务端
      • 2.9 修改zabbix server配置文件,修改密码
      • 2.10 部署web前端进行访问
    • 3 安装Zabbix客户端
      • 3.1 安装客户端
      • 3.2 解决中文乱码问题
    • 4 添加Zabbix客户端主机
      • 4.1 服务端和客户端配置时间同步
      • 4.2 服务端和客户端设置hosts解析
      • 4.3 设置zabbix的下载源,安装zabbix-agent2
      • 4.4 修改agent2配置文件
      • 4.5 启动zabbix-agent2
      • 4.6 服务端验证zabbix-agent2连通性
      • 4.7 Web页面添加agent主机

zabbix

1 zabbix简介

一款基于web界面分布式系统监视以及网络监视功能的企业级开源服务
zabbix服务部署_第1张图片

1.1 组成部件

  • zabbix server
    • 通过zabbix agent、SNMP协议、端口监视等方法提供对远程服务器/网络状态的监视、数据收集等功能
  • zabbix agent
    • 需要安装在被监视的目标服务器上
    • 完成对硬件信息或与操作系统有关的内存、CPU等信息的收集

1.2 监控原理

  1. zabbix agent 安装在被监控的主机上,zabbix agent 负责定期收集客户端本地各项数据
  2. zabbix agent将数据发送至zabbix server端
  3. zabbix server 收到数据后, 将数据存储到数据库中
  4. 用户基于 Zabbix Web 可以看到数据在前端展现图像
  5. 被监控的某个具体的项目会设置一个触发器阈值
  6. 当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、 install 等)
    zabbix服务部署_第2张图片

1.3 Zabbix 6.0新特性

  1. Zabbix server高可用防止硬件故障或计划维护期的停机:

•原生选择加入HA群集配置
•定义一个或多个备用节点
•实时监控Zabbix server群集节点的状态
•不需要外部工具即可将Zabbix server配置为HA群集模式

  1. Zabbix 6.0 LTS新增Kubernetes监控功能,可以在Kubernetes系统从多个维度采集指标:

•Kubernetes节点和pods的自动发现和监控
•无代理方式采集Kubernetes pods和节点的信息
•获取Kubernetes节点主机高水平信息

1.4 Zabbix6.0功能组件

1.4.1 Zabbix Server

zabbix 服务端守护进程,是 Zabbix 软件的核心组件,Zabbix Agent 向其报告可用性、系统完整性信息和统计信息

存储所有配置信息、统计信息和操作信息

也是 Zabbix 监控系统的告警中心。在监控的系统中出现任何异常,将发出通知给管理员

1.4.2 数据库

所有配置信息以及 Zabbix 采集到的数据都被持久存储在数据库中

可以支持 MySQL、PostgreSQL、Oracle、DB2、TimescaleDB 等多种数据库

1.4.3 Web界面

用于实现展示和配置的界面

基于 Apache/Nginx + PHP 实现,早期只支持 LAMP 架构,从 Zabbix5.0 开始支持 LNMP

1.4.4 Zabbix Agent

部署在被监控目标上,用于主动监控本地资源和应用程序

将收集的数据发送给 Zabbix Server

1.4.5 Zabbix Proxy

zabbix 分布式代理守护进程,可以代替 Zabbix Server 采集性能和可用性数据

Zabbix Proxy 的部署可以很好的分担单个 Zabbix Server 的负载

通常监控大于 500 台主机时使用,需要进行分布式监控架构部署

1.4.6 Java Gateway

监控 Tomcat 服务或其它 JAVA 程序(比例 Elasticsearch、ZooKeeper)

需要使用 Java Gateway 做为代理,才能从 JAVA 程序中获取数据


2 部署zabbix服务端

2.1 部署Nginx

cat > /etc/yum.repos.d/nginx.repo << 'EOF'
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
EOF
 
yum install -y nginx

zabbix服务部署_第3张图片
zabbix服务部署_第4张图片

2.2 安装PHP

curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum install -y epel-release
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum -y install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-gd php72w-mbstring php72w-pdo php72w-xml php72w-fpm php72w-mysqlnd php72w-opcache php72w-ldap php72w-bcmath

zabbix服务部署_第5张图片
zabbix服务部署_第6张图片
在这里插入图片描述

2.3 修改Nginx配置

vim /etc/nginx/conf.d/default.conf
server {
  listen 146;
  server_name zbx.kgc.com;
  root /var/www/zbx;
  
  location / {
    index index.php;
  }
  
  location ~ \.php$ {
    fastcgi_pass 127.0.0.1:9000;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME /var/www/zbx$fastcgi_script_name;
    include fastcgi_params;
  }
}

zabbix服务部署_第7张图片
zabbix服务部署_第8张图片

2.4 修改PHP配置

vim /etc/php-fpm.d/www.conf
user = nginx
group = nginx
 
vim /etc/php.ini
max_execution_time = 300		# 368行
max_input_time = 600			# 378行
post_max_size = 146M				# 656行
date.timezone = Asia/Shanghai	# 877行

zabbix服务部署_第9张图片
zabbix服务部署_第10张图片
在这里插入图片描述
在这里插入图片描述

2.5 创建目录和测试文件

mkdir -p /var/www/zbx
 
vim /var/www/zbx/index.php

zabbix服务部署_第11张图片

systemctl enable --now nginx php-fpm

在这里插入图片描述

测试访问(hosts解析)
修改 C:\Windows\System32\drivers\etc\hosts
192.168.146.20 zbx.kgc.com
 
浏览器访问:http://zbx.kgc.com/index.php

zabbix服务部署_第12张图片
zabbix服务部署_第13张图片

2.6 部署Mariadb yum源

cat > /etc/yum.repos.d/mariadb.repo << EOF
[mariadb]
name = MariaDB
baseurl = http://mirrors.aliyun.com/mariadb/yum/10.5/centos7-amd64/
gpgkey = http://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck = 1
enabled=1
EOF
 
yum install -y mariadb-server mariadb
 
systemctl enable --now mariadb

zabbix服务部署_第14张图片
在这里插入图片描述

2.7 初始化数据库

mysql_secure_installation
分别输入 回车 -> n -> Y (设置root密码,如abc123) -> 后面一路 Y
 
mysql -u root -pabc123

zabbix服务部署_第15张图片

创建数据库并指定字符集
CREATE DATABASE zabbix character set utf8 collate utf8_bin;
 
#创建 zabbix 数据库用户并授权
GRANT all ON zabbix.* TO 'zabbix'@'localhost' IDENTIFIED BY 'zabbix';
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
flush privileges;

zabbix服务部署_第16张图片

向数据库导入 zabbix 数据
上传源码包 zabbix-6.0.13.tar.gz 到 /opt 目录
cd /opt
tar xf zabbix-6.0.13.tar.gz
 
ls /opt/zabbix-6.0.13/database/mysql
data.sql  double.sql  history_pk_prepare.sql  images.sql  Makefile.am  Makefile.in  schema.sql

zabbix服务部署_第17张图片

按照顺利导入数据库
cd /opt/zabbix-6.0.13/database/mysql
mysql -uroot -pabc123 zabbix < schema.sql
mysql -uroot -pabc123 zabbix < images.sql
mysql -uroot -pabc123 zabbix < data.sql
mysql -uroot -pabc123 zabbix < double.sql
mysql -uroot -pabc123 zabbix < history_pk_prepare.sql

zabbix服务部署_第18张图片

2.8 编译安装zabbix server服务端

#安装依赖包,创建 zabbix 用户
yum install -y mysql-devel pcre-devel openssl-devel zlib-devel libxml2-devel net-snmp-devel net-snmp libssh2-devel OpenIPMI-devel libevent-devel openldap-devel libcurl-devel fping gcc gcc-c++ make
 
useradd -s /sbin/nologin -M zabbix
 
#编译安装
cd /opt/zabbix-6.0.13/
 
./configure \
--sysconfdir=/etc/zabbix/ \
--enable-server \
--with-mysql \
--with-net-snmp \
--with-libxml2 \
--with-ssh2 \
--with-openipmi \
--with-zlib \
--with-libpthread \
--with-libevent \
--with-openssl \
--with-ldap \
--with-libcurl \
--with-libpcre
 
make install

zabbix服务部署_第19张图片

2.9 修改zabbix server配置文件,修改密码

vim /etc/zabbix/zabbix_server.conf 
......
LogFile=/var/log/zabbix_server.log		# 38行,指定 zabbix 日志路径,需要去/var/log下面创建zabbix_server.log文件,并且给权限777
DBPassword=zabbix					# 123行,指定 zabbix 数据库的密码

在这里插入图片描述
在这里插入图片描述

准备 systemctl 服务管理文件
cat > /usr/lib/systemd/system/zabbix-server.service << EOF
[Unit]
Description=Zabbix Server with MySQL DB
After=syslog.target network.target mysqld.service
 
[Service]
Type=simple
ExecStart=/usr/local/sbin/zabbix_server -f
User=zabbix
 
[Install]
WantedBy=multi-user.target
EOF
 
systemctl daemon-relead
systemctl enable --now zabbix-server
 
netstat -lntp | grep 10051			#zabbix_server 默认监听 10051 端口

zabbix服务部署_第20张图片
在这里插入图片描述
在这里插入图片描述

2.10 部署web前端进行访问

cp -r /opt/zabbix-6.0.13/ui/* /var/www/zbx
 
chown -R nginx.nginx /var/www/zbx
 
浏览器访问:http://zbx.kgc.com/ 
【Default language】选择 Chinese(zh_CN),点击下一步
【密码】输入 zabbix,点击下一步
【Zabbix主机名称】输入 Zabbix-监控;【默认时区】选择 Asia/Shanghai,点击下一步
 
安装完成后,默认的登录账号和密码为:Admin/zabbix

在这里插入图片描述
zabbix服务部署_第21张图片
zabbix服务部署_第22张图片
zabbix服务部署_第23张图片
zabbix服务部署_第24张图片
zabbix服务部署_第25张图片

3 安装Zabbix客户端

3.1 安装客户端

rpm -ivh https://repo.zabbix.com/zabbix/6.0/rhel/7/x86_64/zabbix-release-6.0-4.el7.noarch.rpm
sed -i 's#https://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo
 
#zabbix 5.0 版本开始采用 golang 语言开发的新版本客户端 agent2
yum install -y zabbix-agent2
 
systemctl enable --now zabbix-agent2
 
netstat -lntp | grep 10050			#客户端 zabbix_agent2 默认监听 10050 端口

zabbix服务部署_第26张图片
zabbix服务部署_第27张图片

3.2 解决中文乱码问题

yum install -y wqy-microhei-fonts
 
\cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /var/www/zbx/assets/fonts/DejaVuSans.ttf
 
刷新浏览器页面

zabbix服务部署_第28张图片
zabbix服务部署_第29张图片


4 添加Zabbix客户端主机

4.1 服务端和客户端配置时间同步

yum install -y ntpdate
ntpdate -u ntp.aliyun.com 

在这里插入图片描述
在这里插入图片描述

4.2 服务端和客户端设置hosts解析

cat > /etc/hosts << EOF
192.168.146.20 zbx-server
192.168.146.30 zbx-agent01
EOF

zabbix服务部署_第30张图片
zabbix服务部署_第31张图片

4.3 设置zabbix的下载源,安装zabbix-agent2

rpm -ivh https://repo.zabbix.com/zabbix/6.0/rhel/7/x86_64/zabbix-release-6.0-4.el7.noarch.rpm
sed -i 's#https://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo
 
yum install -y zabbix-agent2

在这里插入图片描述

4.4 修改agent2配置文件

vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.146.20			#146行,指定 zabbix 服务端的 IP 地址
ServerActive=192.168.146.20		#133行,指定 zabbix 服务端的 IP 地址
Hostname=zbx-agent01			#144行,指定当前 zabbix 客户端的主机名

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.5 启动zabbix-agent2

systemctl start zabbix-agent2
systemctl enable zabbix-agent2
 
netstat -natp | grep zabbix
tcp6       0      0 :::10050                :::*                    LISTEN      43654/zabbix_agent2 

zabbix服务部署_第32张图片

4.6 服务端验证zabbix-agent2连通性

yum install -y zabbix-get				#安装 zabbix 主动获取数据的命令
 
zabbix_get -s '192.168.146.30' -p 10050 -k 'agent.ping'
1
 
zabbix_get -s '192.168.146.30' -p 10050 -k 'system.hostname'
zbx-agent01

在这里插入图片描述

4.7 Web页面添加agent主机

点击左边菜单栏【配置】中的【主机】,点击【创建主机】
【主机名称】输入 zbx-agent01
【可见的名称】输入 zbx-agent01-192.168.146.30
【模板】搜索 Linux ,选择 Linux by Zabbix agent
【群组】选择 Linux servers
【Interfaces】点击添加 客户端,【IP地址】输入 192.168.146.30

zabbix服务部署_第33张图片
zabbix服务部署_第34张图片

在这里插入图片描述

你可能感兴趣的:(zabbix,zabbix,云计算,分布式)