• 分布式应用之监控平台zabbix的认识与搭建


    内容预知

    1.监控系统的相关知识 

     1.1 监控系统运用的原因

     1.2 网站的可用性

    1.3 市面上常用的监控系统 

      2.zabbix的相关知识

    2.1 zabbix的概述

    2.2 zabbix 是什么?

    2.3 zabbix的监控原理 

    2.4  zabbix监控系统中五个常用程序

     3.  zabbix 服务端的部署 

    4. 部署 zabbix 客户端 

    1.监控系统的相关知识 

     

     1.1 监控系统运用的原因

     当我们需要实时关注与其相关的各项指标是否正常,往往存在着很多的服务器、网络设备等硬件资源,如果我们想要能够更加方便的、集中的监控他们,zabix可以实现集中监控管理的应用程序

    监控的初衷就是当某些指标不符合我们的需求时,我们能够在第一时间发现异常。

    监控可以给我带来:

    在需要的时刻,提起提醒我们服务器出问题

    当出问题之后,可以找到问题的根源

    网站/服务器的可用性
     

     1.2 网站的可用性

     

    当系统的高可用性,里衡量其可靠性的标准 是用 n个9来表示,在一年之中系统使用时间与总时间的一个比值,值越高可靠性越强,用不同9的个数级别代表系统的稳定性。

    1个9:(1-90%)*365=36.5天,表示该软件系统在连续运行1年时间里最多可能的业务中断时间是36.5天

    2个9:(1-99%)*365=3.65天 , 表示该软件系统在连续运行1年时间里最多可能的业务中断时间是3.65天

    3个9:(1-99.9%)*365*24=8.76小时,表示该软件系统在连续运行1年时间里最多可能的业务中断时间是8.76小时

    4个9:(1-99.99%)*365*24=0.876小时=52.6分钟,表示该软件系统在连续运行1年时间里最多可能的业务中断时间是52.6分钟

    5个9:(1-99.999%)*365*24*60=5.26分钟,表示该软件系统在连续运行1年时间里最多可能的业务中断时间是5.26分钟

    6个9:(1-99.9999%)*365*24*60*60=31秒, 示该软件系统在连续运行1年时间里最多可能的业务中断时间是31秒
     

    像一些大厂,甚至能达到了20个9这样的夸张程度 

     

     

    1.3 市面上常用的监控系统 

     

    市场上常用的监控软件:

    • 传统运维:zabbix、 Nagios
    • 云原生环境: Prometheus (go语言开发的)

     

     

     

     

      2.zabbix的相关知识

    2.1 zabbix的概述

    zabbix是一个开源的监控系统,提供了分布式监控以及集中的web管理页面

     zabbix具备常见商业监控软件所具备的功能,主机性能监控,网络设备性能监控,数据库性能监控,ftp、http等通用协议的监控,当被监控的指标异常可以发送基于 E-mail的报警

    zbbix提供报表及实时的图形化数据处理,实现对监控主机7x24小时集中监控

    Zabbix通过C/S模式采集监控数据,通过B/S模式在web端展示和配置,被监控对象只需要支持SNMP协议或者运行Zabbix agents代理程序即可,服务端监听端口为 10051,被监控端即Zabbix——agents代理程序监控10050端口

     

    2.2 zabbix 是什么?

     

    • zabbix是一个基于Web界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
    • zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
    • zabbix由2部分构成,zabbix server 与可选组件zabbix agent。 通过c/s 模式采集数据,通过B/s模式在web端展示和配置。
    • zabbix server 可以通过SNMP(简单网络管理协议),zabbix agent,ping, 端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它 可以运行在Linux等平台上。(支持多个平台,windows也支持)
    • zabbix agent需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU等信息的收集。

     

     

    2.3 zabbix的监控原理 

     

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

     

    2.4  zabbix监控系统中五个常用程序

     

    ●zabbix server:zabbix 服务端守护进程,其中 zabbix_agent、zabbix_get、zabbix_sender、zabbix_proxy 的数据最终都提交给 zabbix server;
    ●zabbix agent:客户端守护进程,负责收集客户端数据,例如:收集 CPU 负载、内存、硬盘使用情况等;
    ●zabbix proxy:zabbix 分布式代理守护进程,通常大于 500 台主机,需要进行分布式监控架构部署;
    ●zabbix get:zabbix 数据接收工具,单独使用的命令,通常在 server 或者 proxy 端执行获取远程客户端信息的命令;
    ●zabbix sender:zabbix 数据发送工具,用户发送数据给 server 或 proxy 端,通常用户耗时比较长的检查。

     

     

     3.  zabbix 服务端的部署 

     

    1. zabbix-server 内存至少 2G,推荐 4G;
    2. systemctl disable --now firewalld
    3. setenforce 0
    4. hostnamectl set-hostname zbx-server
    5. //获取 zabbix 的下载源
    6. rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
    7. //更换 zabbix.repo 为阿里源
    8. cd /etc/yum.repos.d
    9. sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
    10. yum clean all && yum makecache
    11. yum install -y zabbix-server-mysql zabbix-agent
    12. //安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。软件包会安装在 /etc/opt/rh 目录下。
    13. yum install -y centos-release-scl
    14. //修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
    15. vim zabbix.repo
    16. ......
    17. [zabbix-frontend]
    18. ......
    19. enabled=1 #开启安装源
    20. ......
    21. yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
    22. //安装 zabbix 所需的数据库
    23. yum install -y mariadb-server mariadb
    24. systemctl enable --now mariadb
    25. mysql_secure_installation #初始化数据库,并设置密码,如 abc123
    26. //添加数据库用户,以及 zabbix 所需的数据库信息
    27. mysql -u root -pabc123
    28. CREATE DATABASE zabbix character set utf8 collate utf8_bin;
    29. GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
    30. flush privileges;
    31. //导入数据库信息
    32. rpm -ql zabbix-server-mysql #查询 sql 文件的位置
    33. zcat /usr/share/doc/zabbix-server-mysql-5.0.29/create.sql.gz | mysql -uroot -pabc123 zabbix
    34. //修改 zabbix server 配置文件,修改数据库的密码
    35. vim /etc/zabbix/zabbix_server.conf
    36. ......
    37. DBPassword=zabbix #124行,指定 zabbix 数据库的密码
    38. //修改 zabbix 的 php 配置文件
    39. vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
    40. ......
    41. php_value[date.timezone] = Asia/Shanghai #24行,取消注释,修改时区
    42. //启动 zabbix 相关服务
    43. systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
    44. systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm
    45. 浏览器访问:http://192.168.73.113/zabbix
    46. 点击下一步,设置数据库的密码 zabbix
    47. 安装完成后,默认的登录账号和密码为:Admin/zabbix
    48. 设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 更新。
    49. //解决 zabbix-server Web页面中文乱码问题
    50. yum install -y wqy-microhei-fonts
    51. \cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf

     

     

    4. 部署 zabbix 客户端 

     

    1. zabbix 5.0 版本采用 golang 语言开发的新版本客户端 agent2
    2. zabbix 服务端 zabbix_server 默认使用 10051 端口,客户端 zabbix_agent2 默认使用 10050 端口。
    3. systemctl disable --now firewalld
    4. setenforce 0
    5. hostnamectl set-hostname zbx-agent01
    6. //服务端和客户端都配置时间同步
    7. yum install -y ntpdate
    8. ntpdate -u ntp.aliyun.com
    9. //客户端配置时区,与服务器保持一致
    10. mv /etc/localtime{,.bak}
    11. ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    12. date
    13. //设置 zabbix 的下载源,安装 zabbix-agent2
    14. rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
    15. cd /etc/yum.repos.d
    16. sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo
    17. yum install -y zabbix-agent2
    18. //修改 agent2 配置文件
    19. vim /etc/zabbix/zabbix_agent2.conf
    20. ......
    21. Server=192.168.73.113 #80行,指定 zabbix 服务端的 IP 地址
    22. ServerActive=192.168.73.113 #120行,指定 zabbix 服务端的 IP 地址
    23. Hostname=zbx-agent01 #131行,指定当前 zabbix 客户端的主机名
    24. //启动 zabbix-agent2
    25. systemctl start zabbix-agent2
    26. systemctl enable zabbix-agent2
    27. netstat -natp | grep zabbix
    28. tcp6 0 0 :::10050 :::* LISTEN 43654/zabbix_agent2
    29. //在服务端验证 zabbix-agent2 的连通性
    30. yum install -y zabbix-get #安装 zabbix 主动获取数据的命令
    31. zabbix_get -s '192.168.73.114' -p 10050 -k 'agent.ping'
    32. zabbix_get -s '192.168.73.114' -p 10050 -k 'system.hostname'
    33. //在 Web 页面中添加 agent 主机
    34. 点击左边菜单栏【配置】中的【主机】,点击【创建主机】
    35. 【主机名称】设置成 zbx-agent01
    36. 【可见的名称】设置成 zbx-agent01-192.168.73.114
    37. 【群组】选择 Linux server
    38. 【Interfaces】的【IP地址】设置成 192.168.73.114
    39. 再点击上方菜单栏【模板】
    40. 【Link new tamplates】搜索 Linux ,选择 Template OS Linux by Zabbix agent
    41. 点击 【添加】

     

     

     

     

     ​​​​​​​​​​​​​​​​​​​​​

     ​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​

     ​​​​​​​

     

  • 相关阅读:
    ORACLE表空间说明及操作
    大数据平台迁移后yarn连接zookeeper 异常分析
    【人工智能】本地运行开源项目MMSegmentation引发的问题
    Python 多进程模块 multiprocessing - 简单使用
    需求拆分-软件工程
    Azure DevOps (六) 通过FTP上传流水线制品到Linux服务器
    如何利用AI技术优化独立站客服系统?听听专家怎么说!
    java基于ssm+vue+elementui的旅游线路分享管理系统
    kafka各版本消息介绍
    你与年薪百万的项目经理,可能就差一个字母
  • 原文地址:https://blog.csdn.net/qq_62462797/article/details/127877516