赞
踩
目录
12.1.4清空yum缓存并下载 zabbix-server 和 zabbix-agentd(用于监控本机)
12.1.5修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
12.1.8添加数据库用户,以及 zabbix 所需的数据库信息
12.1.10修改 zabbix server 配置文件,修改数据库的密码
12.1.13浏览器访问http://192.168.246.8/zabbix
12.1.14解决 zabbix-server Web页面中文乱码问题
作为一个运维,需要会使用监控系统查看服务器系统性能、应用服务状态和网站流量指标等,利用监控系统的数据去了解网站上线发布的结果和健康状态
利用一个优秀的监控软件,我们可以:
CPU 负载 、内存使用、 磁盘使用率 、网络状态 、 端口监视 、日志监视 、插件开发自定义
zabbix是C/S架构由zabbbix server和zabbix agent组成
zabbix server :负责存储展示硬件信息,通过B/S模式传给web端展示配置,端口号10051
zabbix agent :监控收集服务器信息,端口号为10050
zabbix server(端口10051):zabbix服务端进程,用于配置和管理zabbix应用程序,也是监控系统的告警中心(需要配置监控项告警触发阈值和发送告警)
zabbix database:持久化存储配置信息和监控指标数据(支持mysql oracle gpdb tsdb等)
zabbix web:用于zabbix服务端配置界面和监控数据的UI界面展示(支持LAMP/LNMP)
zabbix agent(端口10050):部署在被监控的主机上,采集监控指标数据,并发送给zabbix server(数据采集支持主动模式和被动模式)
主动模式:相对于客户端而言:agent向server发起连接
被动模式:相对于客户端而言:server向agent发起连接
如果你有上千台机器需要监控,采用zabbix的主动模式,被动模式sever端的压力太大了
优点:基于两款工具(cacti+Nagios)优点于一身并更强大,集数据采集、数据存储、数据展示及报警功能为一体实现企业级分布式监控 缺点:需在被监控主机上安装agent,所有数据都存在数据库里,产生的数据量很大,瓶颈主要在数据库
- Zabbix_ server:服务端守护进程
- Zabbix_ agentd:agent守护进程
- zabbix_ proxy: 代理服务器
- zabbix database: 存储系统,mysql, pgsq|
- Zabbix_ web:web GUI图形化界面
- Zabbix_ get:命令行工具,测试向agent发起数据采集请求
- Zabbix_ sender:命令行工具,测试向server发 送数据
- Zabbix_ java_ gateway: java网关
重要组件: Zabbix由以下几个组件部分构成: zabbix server:负责接收agent发送的报告信息的核心组件,所有配置,统计数据及操作数据均由其组织进行 database storage:专用于存储所有配置信息,以及由zabbix收集的数据 web interface:zabbix的GUI接口,通常与server运行在同一台主机上 proxy:可选组件,常用于分布式监控环境中,代理server收集部分被监控端的监控数据并同意发往server端 agent:部署在被监控主机上,负责收集本地数据并发往server端或proxy端 常见进程 默认情况下zabbix包含5个进程:zabbix_agentd、zabbix_get、zabbix_proxy、zabbix_sender、zabbix_server,另外一个zabbix_java_gataway是可选的,这个需要另外安装。 Zabbix_agentd:客户端守护进程,此进程收集客户端数据,例如cpu负载、内存、磁盘使用情况等。 Zabbix_get:zabbix工具,单独使用的命令,通常在server或者proxy端执行获取远程客户端信息的命令。通常用来排错。例如在server端获取不到客户端的内存数据,可以使用zabbix_get获取客户端内存的方式来做故障排查。 Zabbix_sender:zabbix工具,用于发送数据给server或者proxy,通常用于耗时比较长的检查。很多检查非常耗时,导致zabbix超时。于是我们在脚本执行完毕之后,使用sender主动提交数据。 Zabbix_server:zabbix服务端守护进程。Zabbix_agentd、zabbix_get、zabbix_sender、zabbix_proxy、zabbix_java_gataway的数据最终都是提交到server,并不是数据都是主动提交给zabbix_server,也有的是sever主动去取数据 Zabbix_proxy:zabbix代理守护进程,功能类似server,唯一不同的是它只是一个中转站,它需要把收集到的数据提交/被提交到sever Zabbix_java_gataway:zabbix2.0之后引入的一个功能,顾名思义:java网关,类似agentd,但是只用于java方面。需要特别注意的是,它只能主动取获取数据,而不能被动获取数据。它的数据最终会给到server或者proxy
在实际监控架构中,zabbix根据网络环境、监控规模等分了三种架构:server-client、master-node-client、server-proxy-client三种
server-client架构
也是zabbix最简单的架构,监控机和被监控机直接不经过任何代理,直接由zabbix server和zabbix agentd之间进行数据交互。适用于网络比较简单,尽量在设备比较少的监控环境,
尽量在同一局域网中,如果一端坏,数据就没有了
server-proxy-client架构
其中proxy是server、client之间沟通的一个桥梁,proxy本身没有前端,而且其本身并不存放数据,而且本身并不存放数据,只是将agentd发来的数据暂时存放,而后再提交给server,该架构经常是和master-node-client架构做比较的架构,一般适用于跨机房、跨网络的中型网络架构的监控,用于大于500台的架构
proxy是缓冲,缓解server的压力
Master-Node-Client该架构
是Zabbix最复杂的监控架构,适用于跨网络、跨机房、设备多的大型环境。每个Node同时接一个Sever端,Node下面可以接Proxy端,也可以直接连接Client,Node有自己的配置文件和数据库,其要做的是将配置信息和监控数据向Master进行数据同步,Master故障损坏对Node其下架构的完整性无任何影响
适用于上千台,上万台的机器的架构
在实际监控架构中,zabbix根据网络环境、监控规模等分了三种架构:server-client、master-node-client、server-proxy-client三种。 server-client架构 也是zabbix最简单的架构,监控机和被监控机直接不经过任何代理,直接由zabbix server和zabbix agentd之间进行数据交互。适用于网络比较简单,设备比较少的监控环境。 server-proxy-client架构 其中proxy是server、client之间沟通的一个桥梁,proxy本身没有前端,而且其本身并不存放数据,只是将agentd发来的数据暂时存放,而后再提交给server。该架构经常是和master-node-client架构做比较的架构,一般适用于跨机房、跨网络的中型网络架构的监控 master-node-clinet架构 该架构是zabbix最复杂的监控架构,适用于跨网络、跨机房、设备较多的大型环境。每个node同时也是一个server端,node下面可以接proxy,也可以直接接client。Node有自己的配置文件和数据库,其要做的是将配置信息和监控数据向master同步
12.1部署Zabbix服务端
zabbix-server 内存至少 2G,推荐 4G
一台2核4G内存数据库,至少2核2G
服务器类型 | 系统和IP地址 | 备注 |
---|---|---|
server服务器 | CentOS7.4(64 位) 192.168.246.8 | 4G内存、zabbix-server-mysql、zabbix-agent、centos-release-scl |
- systemctl disable --now firewalld
- #永久关闭并现在立即关闭防火墙
- setenforce 0
- #关闭selinux
- hostnamectl set-hostname zbx-server
- #更改主机名
- rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
- #获得zabbix下载yum源
- cd /etc/yum.repos.d
- sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
- vim zabbix.repo
- #编辑配置文件 开启安装源
- [zabbix-frontend]
- ......
- enabled=1 #1表示开启安装源
- ......
- #进入yum源目录文件并使用sed将国外源替换为阿里云源
- yum clean all && yum makecache
- #清除原理yum源缓存并加载新的yum
- yum install -y zabbix-server-mysql zabbix-agent
- #安装zabbix客户端和服务端
- yum install -y centos-release-scl
- #安装scl,原因为便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4zabbix要求php版本为7.2以上,若达到要求则无须安装scl
- yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
- #安装连接数据库和连接apache前端页面的连接工具
- yum install -y mariadb-server mariadb
- systemctl enable --now mariadb
- #安装并开启数据库
- mysql_secure_installation
- #初始化数据库,并设置密码,如 abc123选择执行,先回车,然后输入2次自己想设置的密码,其他全部yes即可
- CREATE DATABASE zabbix character set utf8 collate utf8_bin;
- #创建zabbix库并设置库格式为utf-8
- GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
- #创建并授权zabbix远程登录用户密码为zabbix
- flush privileges;
- #刷新数据
- rpm -ql zabbix-server-mysql
- #查询zabbix数据库中配置文件的位置
- zcat /usr/share/doc/zabbix-server-mysql-5.0.33/create.sql.gz | mysql -uroot -pabc123 zabbix(导入的库名)
- #将zabbix数据库格式导入数据库中,此处需要等待10s左右
- vim /etc/zabbix/zabbix_server.conf
- DBPassword=zabbix #124行,去掉#注释然后指定 zabbix 数据库的密码
- #编辑zabbix配置文件将设置的远程登录用户的密码zabbix输入进去保存退出
- vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
- php_value[date.timezone] = Asia/Shanghai #24行,取消注释,修改时区
- #编辑php的配置文件,将时区改为亚洲上海,注意去掉前面的;在此文件中表示注释
- systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
- systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm
- #重启zabbix服务php服务并设置开机自启
![](https://csdnimg.cn/release/blogv2/dist/pc/img/newCodeMoreWhite.png)
所有服务器关闭防火墙、关闭防护、修改主机名
- systemctl disable --now firewalld
- setenforce 0
- hostnamectl set-hostname zbx-server
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
- cd /etc/yum.repos.d
- sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
将官方源替换为阿里源,下载速度更快
yum clean all && yum makecache
yum install -y zabbix-server-mysql zabbix-agent
yum install -y centos-release-scl
安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。
软件包会安装在 /opt/rh 目录下
yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
yum install -y mariadb-server mariadb
systemctl enable --now mariadb
mysql_secure_installation
- CREATE DATABASE zabbix character set utf8 collate utf8_bin;
- GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
- flush privileges;
zcat /usr/share/doc/zabbix-server-mysql-5.0.42/create.sql.gz |mysql -uroot -p123123 zabbix
- vim /etc/zabbix/zabbix_server.conf
- ......
- DBPassword=zabbix #124行,指定 zabbix 数据库的密码
- vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
- ......
- php_value[date.timezone] = Asia/Shanghai #24行,取消注释,修改时区
- systemctl restart zabbix-server zabbix-agent.service httpd rh-php72-php-fpm.service
- systemctl enable zabbix-server zabbix-agent.service httpd rh-php72-php-fpm.service
点击下一步,设置数据库的密码 zabbix
安装完成后,默认的登录账号和密码为:Admin/zabbix
设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 更新
①浏览器输入自己部署zabbix地址的服务器地址如本机:http://192.168.246.8/zabbix进入配置页面
②点击netxt step进入下一步检查zabbix配置,所有状态都要为ok,若有问题则需要去服务器侧检查配置
③所有配置都正常则继续点击下一步使用zabbix账户登录数据库
④连接数据库后下一步配置zabbix信息
⑤ 配置完成zabbix后检查配置项然后点击下一步保存安装
⑥信息检查完成后点击结束安装完成
⑦结束后登录验证,默认账户为:Admin 默认密码为:zabbix
⑧登录完成后主页面如下
⑨修改zabbix语言为中文,点击user settings然后选择语言为中文,点击update保存即可
- yum install -y wqy-microhei-fonts
- \cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf
再次刷新查看
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。