分布式监控系统Zabbix3.2跳坑指南

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: zabbix是什么在此就不多作介绍了,可以参考之前的文章 零代码如何打造自己的实时监控预警系统 ,这篇主要介绍安装及注意事项。 主要分为服务端和客户端安装,客户端又分为Linux、Windows。 服务端安装环境 CentOS6.

zabbix是什么在此就不多作介绍了,可以参考之前的文章 零代码如何打造自己的实时监控预警系统 ,这篇主要介绍安装及注意事项。

主要分为服务端和客户端安装,客户端又分为Linux、Windows。

服务端安装环境

CentOS6.8

Zabbix3.2

Mysql5.6

Apache

PHP56w

环境准备

关闭selinux
setenforce 0

进入mysql,创建zabbix用户并授权

mysql -uroot -p CREATE DATABASE zabbix CHARACTER SET utf8 COLLATE utf8_bin;

GRANT ALL PRIVILEGES ON zabbix.* TO zabbix@'%' IDENTIFIED BY 'zabbix';

安装apache、php

依次安装,虽然说是离线安装,但还是需要联网下载一些包,如果自己手动下载再安装的话会掉入一个个连环坑。


yum install php-pecl-ssh2.x86_64 libssh2-devel.x86_64 net-snmp* OpenIPMI OpenIPMI-devel -y

yum install --skip-broken rpm-build curl* curl-devel httpd php56w php56w-gd php56w-mysql php56w-bcmath php56w-mbstring php56w-xml php56w-ldap -y

yum install gcc libxml2-devel unixODBC-devel net-snmp-devel
libcurl-devel libssh2-devel OpenIPMI-devel openssl-devel openldap-devel –y

 

在这里centos6.8里面的php是一个低版本php54w的,因此需要安装php56w,并重启httpd 和mysqld服务

修改php配置文件


vim /etc/php.ini
post_max_size=16M
max_execution_time=300
max_input_time=300
date.timezone=Asia/Shanghai
always_populate_raw_post_data=-1


启动apache
service httpd start
调整防火墙配置,没加会访问出错 

-A INPUT -m state --state NEW -m tcp -p tcp --dport 10050 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 10051 -j ACCEPT

添加zabbix服务端口

vim /etc/services
zabbix-agent 10050/tcp # Zabbix Agent
zabbix-agent 10050/udp # Zabbix Agent
zabbix-trapper 10051/tcp # Zabbix Trapper
zabbix-trapper 10051/udp # Zabbix Trapper

保存退出!

安装zabbix

创建用户

groupadd zabbix
useradd -g zabbix zabbix

创建zabbix文件夹

mkdir /usr/local/zabbix

cd /usr/local/zabbix

下载zabbix3.2 
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/3.2.0/zabbix-3.2.0.tar.gz
解压
tar zxvf zabbix-3.2.0.tar.gz

进入zabbix文件数据库导入表

 

cd /usr/local/zabbix/zabbix-3.2.0/database/mysql

mysql -u zabbix -p zabbixzabbix<schema.sql

mysql -u zabbix -p zabbixzabbix<images.sql

mysql -u zabbix -p zabbixzabbix<data.sql


下载依赖包

yum install -y gcc mysql-community-devel libxml2-devel unixODBC-devel net-snmp-devel libcurl-devel libssh2-devel OpenIPMI-devel openssl-devel openldap-devel fping

编译安装zabbix

这里面的zabbix为编译后的zabbix文件夹,zabbix-3.2.0为源文件

cd /usr/local/zabbix/zabbix-3.2.0/

./configure --prefix=/usr/local/zabbix --enable-server --enable-agent --enable-java --enable-proxy -with-mysql --with-net-snmp --with-libcurl --with-libxml2 --with-unixodbc --with-ssh2 --with-openipmi --with-openssl --with-java-gateway
make install

修改zabbix_server配置文件

或在编译目录下/usr/local/zabbix/etc/zabbix_agentd.conf

vim /usr/local/etc/zabbix_server.conf
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
FpingLocation=/usr/sbin/fping

DBSocket=/usr/local/mysql5.6/data/mysql.sock 这里填你本机数据库的sock //我发现如果不加,zabbix会一直报connection to database 'zabbix' failed: [2002] Can't connect to local MySQL server through socket mysql.sock'。
ListenIP=你的zabbix_server监听的IP地址 这里的配置一定要写正确,否则后面会出很多问题

创建zabbix-web页面文件夹

在/var/www/html/下创建文件夹 zabbix
mkdir /var/www/html/zabbix
拷贝 php 页面文件到/var/www/html/zabbix 目录下并授权

cd zabbix-3.2.0
cp -R ./frontends/* /var/www/html/zabbix


创建一个规则允许web服务器访问前端文件
chcon -Rv --type=httpd_sys_content_t /var/www/html

chmod +x /var/www/html/zabbix/php/conf/

 

运行Apache和zabbix访问外网
setsebool -P httpd_can_network_connect=1

setsebool -P zabbix_can_network=1

 

编辑zabbix前端的PHP配合配置

vim /etc/httpd/conf.d/zabbix.conf
php_value max_execution_time 300
php_value memory_limit 128M
php_value post_max_size 16M
php_value upload_max_filesize 2M
php_value max_input_time 300
php_value always_populate_raw_post_data -1
php_value date.timezone Asia/Shanghai //主要去掉# 改成上海
不设置会导致异常:Time zone for PHP is not set (configuration parameter "date.timezone").

 拷贝启动脚本到/etc/init.d

cp /usr/local/zabbix/zabbix-3.2.0/misc/init.d/fedora/core/zabbix_server /etc/init.d/zabbix_server
cp /usr/local/zabbix/zabbix-3.2.0/misc/init.d/fedora/core/zabbix_agentd /etc/init.d/zabbix_agentd
chkconfig --add /etc/init.d/zabbix_server
chkconfig --add /etc/init.d/zabbix_agentd

 

修改 basedir:这里面的zabbix为编译后的zabbix文件夹

vi /etc/init.d/zabbix_server
BASEDIR=/usr/local/换成BASEDIR=/usr/local/zabbix
vi /etc/init.d/zabbix_agentd
BASEDIR=/usr/local/换成BASEDIR=/usr/local/zabbix
ln -s /usr/local/zabbix/sbin/zabbix_server /usr/local/sbin/
ln -s /usr/local/zabbix/sbin/ /usr/local/sbin/

 

解决前端显示中文问题


cd /var/www/html/zabbix/fonts/
将中文字体放入
msyh.ttf
修改php配置文件

vim /var/www/html/zabbix/include/defines.inc.php

define('ZBX_FONT_NAME', 'msyh');

define('ZBX_GRAPH_FONT_NAME', 'msyh'); // font file name

 

进入主页面:下面进行,将语言改为中文。
 vim /usr/share/zabbix/include/locales.inc.php
找到第55行,将false改为true

 

启用Zabbix服务器,Apache和MySQL服务启动

chkconfig httpd on
chkconfig mysqld on
chkconfig zabbix_server on
chkconfig zabbix_agentd on
 

全面启动 

 

service zabbix_server start

service zabbix_agentd start

 登陆zabbix

http://192.168.80.32/zabbix/setup.php

默认用户名/密码:Admin/zabbix

此时会出现安装界面,然后点下一步

点击next配置mysql:  

不要用localhost,用主机IP

点击下一步。此步出现错误,发现无法连接数据库,最后发现zabbix这个数据库中,没有任何数据,检查时加红色的那部分出问题。
next到最后

 

默认用户名/密码:Admin/zabbix

 点击zabbix右上角小人,进行修改:

 再重新刷新页面

至此Zabbix服务端全部搭建完毕。

 

Zabbix客户端安装

下载zabbix3.2

zabbix-3.2.0.tar.gz
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/3.2.0/zabbix-3.2.0.tar.gz

添加服务

vim /etc/services
zabbix-agent 10050/tcp # ZabbixAgent
zabbix-agent 10050/udp # ZabbixAgent
zabbix-trapper 10051/tcp # ZabbixTrapper
zabbix-trapper 10051/udp # ZabbixTrapper

添加用户

 groupadd -g 201 zabbix
useradd -g zabbix -u 201 -s /sbin/nologin zabbix

解压

tar -zxvf zabbix-3.2.0.tar.gz
cd zabbix-3.2.0
./configure --prefix=/usr/local/zabbix --enable-agent
make install


修改agentd配置文件

vi /usr/local/zabbix/etc/zabbix_agentd.conf
Server= 192.168.80.32 #服务端ip地址
ServerActive= 192.168.80.32 #服务端ip地址
Hostname=192.168.80.30  #必须与创建主机时的hostname一致(客户端IP)

修改启动配置,添加软链接

mkdir /var/log/zabbix
chown zabbix.zabbix /var/log/zabbix
cp /usr/local/zabbix/zabbix-3.2.0/misc/init.d/fedora/core/zabbix_agentd /etc/init.d/
chmod 755 /etc/init.d/zabbix_agentd
ln -sv /usr/local/zabbix/sbin/* /usr/local/sbin/
ln -sv /usr/local/zabbix/bin/* /usr/local/bin/

转换文件用户
chown -R zabbix:zabbix /usr/local/zabbix

设置自启动

chkconfig zabbix_agentd on

service zabbix_agentd start

在Server端使用以下命令测试是否能连接到Agent端:
# zabbix_get -s 192.168.80.30 -p 10050 -k "system.uptime"

若没有添加zabbix_get软连接,则加上编译文件夹路径

/usr/local/zabbix/bin/zabbix_get  -s 192.168.80.30 -p 10050 -k "system.uptime"

启动zabbix web端添加主机

 

 

注意上面的IP,与zabbix_agent中配置的hostname要一致

给服务器添加监控模板(自带了一些模板,如果不满足后面可以自己创建)

 

在监控项图表中可查看记录了,如果没数据可能要等一会。

Windows中安装客户端

下载

官网:https://www.zabbix.com/download
下载 zabbix_agents_3.2.0.win.zip
解压缩zabbix_agents_3.2.0.win.zip

在应用程序中文件夹中创建配置目录及文件 conf\zabbix_agent.conf

配置

LogFile=c:\zabbix_agentd.log
EnableRemoteCommands=1 ##激活远程执行脚本
Server=192.168.80.32
ServerActive=192.168.80.32
Hostname=192.168.80.33

注册zabbix agent服务

1 运行cmd进入windows命令行控制台,下面我是将程序放在D:\Soft文件夹下,且对文件夹重命名zabbix_agents_320win
2 运行D:\Soft\zabbix_agents_320win\bin\win64\zabbix_agentd.exe -c D:\Soft\zabbix_agents_320win\conf\zabbix_agentd.conf -i
注:-c表示配置文件路径 -i表示安装

启动

在命令行运行services.msc进入windows服务控制台,找到zabbix_agent服务,右键启动即可

总得来说zabbix客户端中windows比linux安装容易。

最后一点就是如果能用CentOS7就尽量用,6.8的版本有些基础插件版本低,需要自己升级所以安装的时候不是差这就差那的。如果是CentOS7就简单了,导入源:

rpm -ivh http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm

安装zabbix服务包
yum -y install zabbix-server-mysql zabbix-web-mysql
我们给本机也安装上客户端
yum -y install zabbix-agent

不过安装的位置是默认的。

安装问题汇总

zabbix_server启动报错---解决方法

Starting Zabbix Server: /opt/app/zabbix/sbin/zabbix_server: error while loading shared libraries: libmysqlclient.so.16: cannot open shared object file: No such file or directory

vim /etc/ld.so.conf 加入
/usr/local/mysql5.6/lib  mysql安装路径换成自己的

zabbix web页面中添加的主机的可用性状态显示“received empty response from zabbix agent at.......”

解决方法:agent配置文件中的Server填写的IP不对,一定要填写zabbix_server的监听IP。确认配置文件没问题后,还有一个原因,在创建主机的时候,IP地址填写的不正确,要填写agent的IP地址。更改即可

vi /etc/zabbix/zabbix_agentd.conf //修改zabbix_agentd.conf参数
Server=192.168.80.32 //安装zabbix服务端的机器的IP
ServerActive=192.168.80.32 //安装zabbix服务端的机器的IP
Hostname=192.168.80.31 //我这以被监控的机器的ip作为Hostname,注意是被监控的,而且要与监控页面的监控主机名一致

 

安装过程中遇到Requires: libc.so.6(GLIBC_2.17)(64bit) 怎么办?

网上有说

cp /usr/local/glibc-2.17/lib/libc-2.17.so /lib64/libc-2.17.so
mv /lib64/libc.so.6 /lib64/libc.so.6.bak (但这样会导致整个系统错误,结果悲剧了 登录不了服务器,最后只能找其它方法修复系统,libc.so是一个系统级的文件,不能随便删除,但在centos7环境下不存在此问题)

 

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
53 23
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
47 22
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
58 25
盘古分布式存储系统的稳定性实践
本文介绍了阿里云飞天盘古分布式存储系统的稳定性实践。盘古作为阿里云的核心组件,支撑了阿里巴巴集团的众多业务,确保数据高可靠性、系统高可用性和安全生产运维是其关键目标。文章详细探讨了数据不丢不错、系统高可用性的实现方法,以及通过故障演练、自动化发布和健康检查等手段保障生产安全。总结指出,稳定性是一项系统工程,需要持续迭代演进,盘古经过十年以上的线上锤炼,积累了丰富的实践经验。
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
37 7
使用 Zabbix 监控堆外应用
使用 Zabbix 监控堆外应用
61 9
zabbix全面的监控能力
zabbix全面的监控能力
108 7
分布式机器学习系统:设计原理、优化策略与实践经验
本文详细探讨了分布式机器学习系统的发展现状与挑战,重点分析了数据并行、模型并行等核心训练范式,以及参数服务器、优化器等关键组件的设计与实现。文章还深入讨论了混合精度训练、梯度累积、ZeRO优化器等高级特性,旨在提供一套全面的技术解决方案,以应对超大规模模型训练中的计算、存储及通信挑战。
91 4
构建高可用性GraphRAG系统:分布式部署与容错机制
【10月更文挑战第28天】作为一名数据科学家和系统架构师,我在构建和维护大规模分布式系统方面有着丰富的经验。最近,我负责了一个基于GraphRAG(Graph Retrieval-Augmented Generation)模型的项目,该模型用于构建一个高可用性的问答系统。在这个过程中,我深刻体会到分布式部署和容错机制的重要性。本文将详细介绍如何在生产环境中构建一个高可用性的GraphRAG系统,包括分布式部署方案、负载均衡、故障检测与恢复机制等方面的内容。
174 4
构建高可用性GraphRAG系统:分布式部署与容错机制
监控堆外第三方监控工具Zabbix
监控堆外第三方监控工具Zabbix
54 5

推荐镜像

更多
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等