文章目录
- 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界面的分布式系统监视以及网络监视功能的企业级开源服务
1.1 组成部件
- zabbix server
- 通过zabbix agent、SNMP协议、端口监视等方法提供对远程服务器/网络状态的监视、数据收集等功能
- zabbix agent
- 需要安装在被监视的目标服务器上
- 完成对硬件信息或与操作系统有关的内存、CPU等信息的收集
1.2 监控原理
- zabbix agent 安装在被监控的主机上,zabbix agent 负责定期收集客户端本地各项数据
- zabbix agent将数据发送至zabbix server端
- zabbix server 收到数据后, 将数据存储到数据库中
- 用户基于 Zabbix Web 可以看到数据在前端展现图像
- 被监控的某个具体的项目会设置一个触发器阈值
- 当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、 install 等)
1.3 Zabbix 6.0新特性
- Zabbix server高可用防止硬件故障或计划维护期的停机:
•原生选择加入HA群集配置
•定义一个或多个备用节点
•实时监控Zabbix server群集节点的状态
•不需要外部工具即可将Zabbix server配置为HA群集模式
- 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
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
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;
}
}
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行
2.5 创建目录和测试文件
mkdir -p /var/www/zbx
vim /var/www/zbx/index.php
<?php
phpinfo();
?>
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
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
2.7 初始化数据库
mysql_secure_installation
分别输入 回车 -> n -> Y (设置root密码,如abc123) -> 后面一路 Y
mysql -u root -pabc123
创建数据库并指定字符集
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 数据
上传源码包 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
按照顺利导入数据库
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
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
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 端口
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
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 端口
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
刷新浏览器页面
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
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
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