zabbix企业级监控平台

zabbix部署

安装源

重新创建纯净环境,利用base克隆一台虚拟机server1

给server1做快照,方便下次实验恢复使用

进入zabbix官网https://www.zabbix.com

rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm

#安装 Zabbix 监控系统的 YUM 软件源配置包。这个命令将会下载并安装 Zabbix 5.0 版本适用于 CentOS/RHEL 7 x86_64 系统的软件源配置文件 zabbix-release-5.0-1.el7.noarch.rpm。

官网的yum源下载速度慢,可以使用清华下载站

vim zabbix.repo

yum clean all

#清理yum的缓存,包括下载的软件包和元数据。通过运行这个命令,可以释放磁盘空间并确保系统中使用的软件包信息是最新的

yum install zabbix-server-mysql zabbix-agent

#安装Zabbix server,Web前端,agent

安装 Zabbix 前端和启用 Red Hat Software Collections:

yum install -y centos-release-scl-2-3.el7.centos.noarch.rpm  centos-release-scl-rh-2-3.el7.centos.noarch.rpm

#安装

yum repolist

#列出系统中配置的 YUM 软件源(repositories)以及它们的状态和信息

yum install zabbix-web-mysql-scl zabbix-apache-conf-scl

#安装前端界面包

tar xf mysql-5.7.33-1.el7.x86_64.rpm-bundle.tar

#解压编译好的mysql开发包

yum install -y mysql-community-client-5.7.33-1.el7.x86_64.rpm mysql-community-common-5.7.33-1.el7.x86_64.rpm mysql-community-libs-5.7.33-1.el7.x86_64.rpm mysql-community-libs-compat-5.7.33-1.el7.x86_64.rpm mysql-community-server-5.7.33-1.el7.x86_64.rpm

#安装rpm软件包,这种安装方法速度快

systemctl status mysqld

#查看mysql状态,自动创建了启动脚本

systemctl enable --now mysqld

#开机自启

grep 'temporary password' /var/log/mysqld.log

#过滤日志中记录的临时密码

mysql_secure_installation

#安全初始化,设置新密码为YQMyqm0626*

mysql -pYQMyqm0626*

#登录数据库

创建zabbix数据库:

create database zabbix character set utf8 collate utf8_bin;

#创建一个名为zabbix,字符集为utf8,校对规则为utf8_bin的数据库

create user zabbix@localhost identified by 'YQMyqm0626*';

#中创建一个名为zabbix的用户,允许该用户只能从本地主机(localhost)登录,并设置密码为YQMyqm0626*

grant all privileges on zabbix.* to zabbix@localhost;

#授予zabbix@localhost用户对zabbix数据库的全部权限

set global log_bin_trust_function_creators = 1;

#设置全局变量log_bin_trust_function_creators的值为1,允许在具有二进制日志的 MySQL 实例中创建和修改函数,而无需super权限

zcat /usr/share/doc/zabbix-server-mysql-5.0.42/create.sql.gz | mysql -uzabbix -pYQMyqm0626* zabbix

#导入数据,数据量较大,需要等待,不要中断

可使用zabbix用户身份,已经拥有所有权限

mysql> set global log_bin_trust_function_creators = 0;

#将全局变量log_bin_trust_function_creators的值设为0,禁止在具有二进制日志的 MySQL 实例中创建和修改函数,除非用户具有 SUPER 权限

vim /etc/zabbix/zabbix_server.conf

#编辑配置文件

vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf

#配置zabbix前端

systemctl enable --now zabbix-server zabbix-agent httpd rh-php72-php-fpm

#设置Zabbix 服务器、Zabbix Agent、Apache(httpd)以及 PHP-FPM 服务开机自启

访问前端 http://192.168.145.11/zabbix

填写数据库连接信息

填写zabbix server信息

登陆前端的用户密码是:Admin/zabbix

修改前端语言

修改字体文件

最终指向的是DejaVu Sans 字体,是系统字体

DejaVu Sans 是一种常用的开源无衬线字体,具有良好的可读性和跨平台兼容性,适合用于屏幕显示和打印输出。通过指定这个路径,系统或应用程序可以引用并使用 DejaVu Sans 字体来显示文本内容,以确保文本在界面上能够正确显示并保持一致的外观。

cp simkai.ttf /usr/share/zabbix/assets/fonts

#将下载的楷体字体文件放到字体存储的目录中

rm -f graphfont.ttf

#删除原来的软连接

ln -s simkai.ttf graphfont.ttf

#将graphfont.ttf重新指向simkai.ttf字体文件,可以方便地引用simkai.ttf字体文件,而无需复制或移动文件内容

vim /usr/share/zabbix/include/defines.inc.php

#查看配置文件

指定了字体文件,所以做软链接指向要使用的字体文件即可,不用修改配置文件


添加agent

从母镜像base克隆两台虚拟机server2,server3,设置主机名为server2,server3,ip地址分别为192.168.145.12,192.168.145.13

1.手动添加 

scp zabbix.repo server2:/etc/yum.repos.d/

#从server1拷贝repo文件到server2 

server2:

vim /etc/yum.repo.d/zabbix.repo

yum install -y zabbix-agent

#安装zabbix-agent

vim /etc/zabbix/zabbix_agentd.conf

#编辑配置文件

systemctl enable --now zabbix-agent.service

#启动服务

server端:

2.自动发现

配置server3

scp zabbix.repo server3:/etc/yum.repos.d/

#从server2拷贝repo文件

vim /etc/zabbix/zabbix_agentd.conf

#编辑配置文件

systemctl  enable --now zabbix-agent.service

#启动服务

server端:

打开agent即可

要先启用动作再启用发现

适合通用大批量主机管理,并不具备实时性,因为有时间间隔

3.自动注册

停用自动发现规则

删除server3主机

可根据实际应用场景选择添加不同动作

systemctl restart zabbix-agent.service

#重启server3的agent服务

是由agent端完成动作,具有实时性

自动发现适合大批量通用型添加场景

4.zabbix api

Zabbix API是Zabbix监控系统提供的应用程序接口(Application Programming Interface),用于通过HTTP/HTTPS协议与Zabbix服务器进行通信。通过Zabbix API,用户可以以编程方式执行各种操作,如创建、修改和删除监控项、主机、触发器、图表等。这使得用户可以自动化监控系统的管理和配置,同时也可以将Zabbix集成到其他应用程序或工具中。

Zabbix API提供了RESTful风格的API,支持JSON和XML格式的数据交换。通过调用API方法,用户可以执行各种操作,并获取系统状态和监控数据。例如,可以使用API创建一个新的监控项,获取主机的当前状态,或者检索触发器的历史数据。

使用Zabbix API,用户可以根据自己的需求开发自定义的监控解决方案,或者集成Zabbix监控系统到其它自动化工具和流程中,从而实现更高效的监控管理和自动化运维。

curl -s -X POST http://192.168.145.11/zabbix/api_jsonrpc.php -H 'Content-Type: application/json-rpc' -d '
{
    "jsonrpc": "2.0",
    "method": "user.login",
    "params": {
        "user": "Admin",
        "password": "zabbix"
    },
    "id": 1,
    "auth": null
}' | python -m json.tool

#获取token值

{
    "id": 1,
    "jsonrpc": "2.0",
    "result": "1e4cc57eb1e0583ff63ef25cfdbb581c"
}

#认证后获取的token值

也可将curl命令写入脚本,添加可执行权限,执行脚本即可获得token值

检索主机:

#执行查询操作,获取主机信息以及它们的接口信息

删除主机

删除server3主机,id为10440

修改脚本内容为删除10440主机

./zabbix-api.sh

#执行

创建主机

生效

在生产环境更加适用


服务监控

1.nginx监控 

在server2安装nginx

使用nginx-1.23.3版本

tar zxf nginx-1.23.3.tar.gz

#解压

yum install -y gcc make openssl-devel pcre-devel

#安装依赖性

./configure  --with-http_stub_status_module --with-http_ssl_module

#配置

不指定安装路径,也自动安装到了/usr/local/nginx

make

#编译

make install

#安装

ln -s /usr/local/nginx/sbin/nginx  /usr/local/bin/

#创建软连接,便于启动

vim /usr/local/nginx/conf/nginx.conf

#编辑配置文件,配置stub_status模块

#访问/basic_status路径时,Nginx会返回服务器的简单状态信息

nginx

#启动服务

curl  localhost/basic_status

#访问本地/basic_status,获取服务器简单信息

多次访问

监控显示:

稍作等待,监控数据就会出现,采集数据有一定的时间间隔

在官方文档查看zabbix安装要求

数据库要求:

可根据主机所有监控项换算所需的磁盘大小

2.mysql监控

zabbix自带mysql模板 

为zabbix server链接mysql监控模板

拷贝模板:

cp /usr/share/doc/zabbix-agent-5.0.42/userparameter_mysql.conf /etc/zabbix/zabbix_agentd.d/

#拷贝

创建数据库连接用户

GRANT REPLICATION CLIENT,PROCESS,SHOW DATABASES,SHOW VIEW ON *.* TO 'zbx_monitor'@'%';

#授予了'zbx_monitor'用户在所有数据库上执行以下操作的权限

  • REPLICATION CLIENT: 允许用户查看关于复制的信息,例如主从复制状态。
  • PROCESS: 允许用户查看当前正在执行的进程。
  • SHOW DATABASES: 允许用户查看所有数据库的列表。
  • SHOW VIEW: 允许用户查看数据库中的视图。

这个语句中的*.*表示所有数据库和所有表。'zbx_monitor'@'%'指定了用户的用户名为'zbx_monitor',并且可以从任何主机(%表示任何主机)连接到MySQL服务器。

创建数据库连接文件

mkdir /var/lib/zabbix/

vim /var/lib/zabbix/.my.cnf

systemctl restart zabbix-agent.service

#重启agent

查看mysql监控

percona数据库模板

清理掉原来模板

rpm -ivh percona-zabbix-templates-1.1.8-1.noarch.rpm

#安装 Percona 提供的 Zabbix 模板包

  • -ivh: 这三个选项分别代表:
    • -i: 安装一个新的软件包。
    • -v: 在安装过程中显示详细信息,即 verbose 模式。
    • -h: 在显示安装进度条时,以 hash 标识进度。

cd /var/lib/zabbix/percona/templates

cp userparameter_percona_mysql.conf /etc/zabbix/zabbix_agentd.d/

#拷贝模板,存放key/value

rm -f /etc/zabbix/zabbix_agentd.d/userparameter_mysql.conf

#删除原来的模板

现在模板内容更多

systemctl restart zabbix-agent.service

#重启agent

cd /var/lib/zabbix/percona/scripts/

vim ss_get_mysql_stats.php

#编辑php脚本

ln -s /opt/rh/rh-php72/root/usr/bin/php /usr/bin/php

#创建软连接,方便调用php

/var/lib/zabbix/percona/scripts/get_mysql_stats_wrapper.sh gg

#运行脚本

运行该脚本加上键值gg是获取mysql的key-read-requests指标

有数据显示就表示正常

数据已经做过格式化,key/value机制

此时缓存文件是root身份创建的,最终要实现zabbix用户自行创建

rm -f localhost-mysql_cacti_stats.txt

#删除/tmp下的缓存文件,如果不删除后期则zabbix用户无法修改文件

导入模板文件

等待监控数据生成

3.tomcat监控

yum install -y java-1.8.0-openjdk.x86_64

#安装java openjdk软件包

tar zxf apache-tomcat-8.5.24.tar.gz -C /usr/local

#解压tomcat软件压缩包

cd /usr/local/

ln -s apache-tomcat-8.5.24/ tomcat

#创建软链接

cd /usr/local/tomcat/bin/

vim catalina.sh

#编辑tomcat启动脚本

CATALINA_OPTS='-Dcom.sun.management.jmxremote.port=8888

-Dcom.sun.management.jmxremote.ssl=false

-Dcom.sun.management.jmxremote.authenticate=false'

#配置 Apache Tomcat 服务器的 JMX 远程管理功能,指定 JMX 远程管理的端口为8888

./startup.sh

#启动tomcat服务器

服务不能all in一台服务器

在server1安装java网关:

yum install -y zabbix-java-gateway

#安装zabbix-java-gateway,作为一个中间件,连接 Zabbix Server 和监控的 Java 应用程序之间的通信

systemctl  enable --now zabbix-java-gateway.service

#启动服务

vim /etc/zabbix/zabbix_server.conf

#修改zabbix server配置文件

StartJavaPollers 用于处理 Java 监控数据的 Java Poller 进程的数量。Java Poller 负责从 Java 应用程序中收集监控数据并将其传递给 Zabbix Server。通过设置该参数,可以控制并发处理的 Java 监控数据的数量。在这里,设置为 5,表示启动 5 个 Java Poller 进程

systemctl  restart zabbix-server.service

#重启server

server端:

等待配置

有监控数据生成

4.集成告警平台

睿象云-智能运维找睿象

注册以后创建appkey,按照文档配置探针

部署探针:

cd /usr/lib/zabbix/alertscripts

#切换到zabbix脚本目录

wget https://download.aiops.com/ca_agent/zabbix/ca_zabbix_release-4.0.3.tar.gz

#获取Cloud Alert Agent包

wget命令是一个在Linux和类Unix操作系统中经常使用的网络命令,用途是从指定的URL下载文件。它支持HTTP、HTTPS和FTP协议,支持断点续传,可以下载整个网站

tar xf ca_zabbix_release-4.0.3.tar.gz

#解压

cd cloudalert/bin

./install.sh fd654cbe71c44c28b6155e5862002334

#安装

chown zabbix.zabbix cloudalert/ -R

#将cloudalert/探针目录的所有人和所有组都设为zabbix,保证运行zabbix服务的权限和cloudalert探针目录的权限保持一致

配置通知策略:

app通知需下载app,微信通知需绑定微信公众号

测试:

停止server2的agent服务

被认领

再次启动agent

[root@server2 ~]# systemctl start zabbix-agent.service

平台显示解决

实际生产过程中还可开启智能降噪功能,可智能筛掉无用通知

分布式监控

agent 主动方式

目前模板是server端主动连接agent端10050端口(常规)

Template App Nginx by Zabbix agent

也可以agent主动将数据回传给server端10051口,降低了server端的性能开销

Template App Nginx by Zabbix agent active

zabbix proxy

删除server2 agent作为proxy节点

在三台机器添加本地解析

vim /etc/hosts

yum install zabbix-proxy-mysql

#安装proxy软件

在server1数据库中:

mysql> FLUSH PRIVILEGES;

#重新加载授权表

[root@proxy ~]# cd /usr/share/doc/zabbix-proxy-mysql-5.0.42/

scp schema.sql.gz server1:

#从proxy拷贝数据库文件

该文件用于创建数据库的结构(schema),包括表、视图、索引等的定义

zcat schema.sql.gz | mysql -uzabbix -pYQMyqm0626* zabbix_proxy

#使用zcat解压文件后输出到mysql的zabbix_proxy库中

[root@proxy ~]# vim /etc/zabbix/zabbix_proxy.conf

#编辑proxy配置文件

server端创建proxy

为主机配置代理:

systemctl  restart zabbix-proxy.service

#重启proxy服务

cat /var/log/zabbix/zabbix_proxy.log

#查看日志

[root@server3 ~]# vim /etc/zabbix/zabbix_agentd.conf

#修改agent配置,指向proxy地址

cat /var/log/zabbix/zabbix_agentd.log

#查看日志无报错

监控可用

zabbix瓶颈可能在于数据库,随着监控数据的采集存储,监控项越来越多,对数据库性能的要求会越来越高

推荐TIDB数据库将mysql数据迁移到TIDB,可实现分布式

完成这部分学习可以尝试使用ansible自动化运维工具搭建起整个lnmp架构或者监控平台

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/806382.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

D-Link NAS 未授权RCE漏洞复现(CVE-2024-3273)

0x01 免责声明 请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,作者不为此承担任何责任。工具来自网络,安全性自测,如有侵权请联系删…

SVN的介绍

首先SVN是什么: Apache下的一个开源的项目Subversion,通常缩写为 SVN,是一个版本控制系统。 版本控制系统是一个软件,它可以伴随我们软件开发人员一起工作,让我们编写代码的完整的历史保存下来。 目前它的各个版本的…

实现鼠标在页面点击出现焦点及大十字星

近段时间,在完成项目进度情况显示时候,用户在操作鼠标时候,显示当鼠标所在位置对应时间如下图所示 代码实现步骤如下: 1.首先引用 jquery.1.7.js 2.再次引用raphael.js 3.然后引用graphics.js 4.最后引用mfocus.js 其中mfocu…

3. DAX 时间函数-- DATE 日期--一生二,二生三,三生万物

在数据分析过程中,经常需要从一个数据推到另外一个数据,日期数据也是如此,需要从一个日期推到另外一个相关的日期,或者从一群日期推到另外一个相关的日期/一群相关的日期。这一期说的就是日期之间彼此推衍的函数,会比之…

Linux:自动化构建 - make

Linux:自动化构建 - make make基本概念makefile语法变量PHONY make基本概念 make是一个用于自动化编译和构建过程的工具。它主要用于管理大型软件项目的构建过程,帮助开发者更高效地编译和部署代码,并减少人为错误的发生,这使得软件的编译和…

电商技术揭秘十八:电商平台的云计算与大数据应用小结

电商技术揭秘相关系列文章 电商技术揭秘一:电商架构设计与核心技术 电商技术揭秘二:电商平台推荐系统的实现与优化 电商技术揭秘三:电商平台的支付与结算系统 电商技术揭秘四:电商平台的物流管理系统 电商技术揭秘五&#xf…

【STL】list的模拟实现

目录 前言 list概述 list的节点 list的迭代器 list的结构 构造与析构 拷贝构造与赋值 list的元素操作 insert() push_back() push_front() erase() pop_back() pop_front() clear() swap() size() 完整代码链接 前言 如果你对链表还不熟悉或者忘了的话…

Harmony鸿蒙南向驱动开发-PWM

PWM(Pulse Width Modulation)即脉冲宽度调制,是一种对模拟信号电平进行数字编码并将其转换为脉冲的技术,广泛应用在从测量、通信到功率控制与变换的许多领域中。通常情况下,在使用马达控制、背光亮度调节时会用到PWM模…

微信小程序实现输入appid跳转其他小程序

前言 本文记录wx.navigateToMiniProgram打开另一个小程序API使用方法&#xff0c;并封装为组件。 wxml 部分 输入框用来记录appid&#xff0c;按钮用来查询并跳转。 <view class"container"><input class"input" placeholder"请输入要查…

Flutter Your project requires a newer version of the Kotlin Gradle plugin

在开发Flutter项目的时候,遇到这个问题Flutter Your project requires a newer version of the Kotlin Gradle plugin 解决方案分两步: 1、在android/build.gradle里配置最新版本的kotlin 根据提示的kotlin官方网站搜到了Kotlin的最新版本是1.9.23,如下图所示: 同时在Ko…

python如何写入csv

在使用python对文件操作的过程中&#xff0c;你肯定碰到过对csv文件的操作&#xff0c;下面就python对csv文件的操作进行详述。 CSV&#xff08;Comma-Separated Values&#xff09;逗号分隔符&#xff0c;也就是每条记录中的值与值之间是用分号分隔的。 打开CSV文件并写入一…

实战项目——智慧社区(一)

1、项目介绍 系统功能 登录、修改密码、登出 &#xff08;1&#xff09;首页 &#xff08;1.1&#xff09;数据统计&#xff1a;小区人员统计对比图&#xff0c;占比图 &#xff08;2&#xff09;物业管理 &#xff08;2.1&#xff09;小区管理&#xff1a;小区数据的增删改…

在开发过程中使用 git rebase 还是 git merge

在开发过程中使用 git rebase 还是 git merge Merge(合并)的优点和缺点Rebase(变基)的优点和缺点总结&#xff1a; Git merge 和rebase的目的是一样的&#xff0c;它们都是将多个分支合并成一个。 虽然他们最终的目标是一样的&#xff0c;但这两种方法实现的方式是不同的。那么…

leetcode73 矩阵置零

题目描述 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用原地算法。 输入&#xff1a;matrix [[1,1,1],[1,0,1],[1,1,1]] 输出&#xff1a;[[1,0,1],[0,0,0],[1,0,1]] 输入&#xff1a;matrix [[0,1,2,0],[3,4…

【数据结构】单链表(一)

上一篇【数据结构】顺序表-CSDN博客 我们了解了顺序表&#xff0c;但是呢顺序表涉及到了一些问题&#xff0c;比如&#xff0c;中间/头部的插入/删除&#xff0c;时间复杂度为O(N);增容申请空间、拷贝、释放旧空间会有不小的消耗&#xff1b;增容所浪费的空间... 我们如何去解…

java数据结构与算法刷题-----LeetCode210. 课程表 II

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 深度优先遍历但不进行逆拓扑排序&#xff08;不用栈&#xff09;…

leetcode 343. 整数拆分

题目 给定一个正整数 n &#xff0c;将其拆分为 k 个 正整数 的和&#xff08; k > 2 &#xff09;&#xff0c;并使这些整数的乘积最大化。 返回 你可以获得的最大乘积 。 示例 1: 输入: n 2 输出: 1 解释: 2 1 1, 1 1 1。 示例 2: 输入: n 10 输出: 36 解释: 1…

记一次IP访问MySQL失败多次被自动锁定导致无法连接问题,解决方法只需一条SQL。

&#x1f469;&#x1f3fd;‍&#x1f4bb;个人主页&#xff1a;阿木木AEcru &#x1f525; 系列专栏&#xff1a;《Docker容器化部署系列》 《Java每日面筋》 &#x1f4b9;每一次技术突破&#xff0c;都是对自我能力的挑战和超越。 前言 今天下午还在带着耳机摸鱼&#xff…

Netty的基本架构与组件

Netty实战精髓 前言 Netty的组成部分 1、Channel 2、Callback 3、Future ChannelFuture 提供多个附件方法来允许一个或者多个 ChannelFutureListener 实例&#xff0c;这个回调方法 operationComplete() 会在操作完成时调用。 4、Event和Handler 5、EventLOOP Netty 通过触发…

如何在极狐GitLab 启用依赖代理功能

本文作者&#xff1a;徐晓伟 GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 本文主要讲述了如何在[极狐GitLab…