【30天精通Prometheus:一站式监控实战指南】第13天:graphite_exporter从入门到实战:安装、配置详解与生产环境搭建指南,超详细

亲爱的读者们👋

  欢迎加入【30天精通Prometheus】专栏!📚 在这里,我们将探索Prometheus的强大功能,并将其应用于实际监控中。这个专栏都将为你提供宝贵的实战经验。🚀

  Prometheus是云原生和DevOps的核心监控工具,我们将从基础概念开始,逐步涵盖配置、查询、告警和可视化。💪

  在接下来的30天里,我们将解锁Prometheus的实战技巧,通过案例和分享,助你深入理解其工作原理。📆

  目标:30天后,你将熟练掌握Prometheus,为未来的项目挑战做好准备!💯

  这是一段精彩旅程,期待你的加入!🎉


文章目录

  • 一、graphite_exporter概述📘
  • 二、安装graphite_exporter💾
    • 2.1 访问graphite_exporter官方网站 🌐
    • 2.2 选择适合的版本🔍
    • 2.3 下载graphite_exporter⬇️
    • 2.4 解压安装包📂
    • 2.5 运行graphite_exporter🚀
  • 三、graphite_exporter指标和配置详解📖
    • 3.1 graphite_exporter_mapping
    • 3.2 graphite_exporter.service
  • 四、实战演练:生产环境搭建指南🔨
    • 4.1 创建普通用户管理graphite_exporter👤
    • 4.2 解压graphite_exporter.tar.gz📦
    • 4.3 将graphite_exporter集成到Prometheus配置中✂️
    • 4.4 更改graphite_exporter软件包名称✂️
    • 4.5 编辑graphite_exporter.service文件📝
    • 4.6 启动graphite_exporter.service🔌
    • 4.7 查看服务是否正常启动🔍
  • 相关资料下载地址📚

一、graphite_exporter概述📘

定义
  graphite_exporter 是一个开源的组件或服务,其设计目的是接收通过 Graphite plaintext 协议发送的监控数据,并将这些数据转换为 Prometheus 可以理解的格式。简单来说,graphite_exporter 充当了一个转换桥梁,使得原本使用 Graphite 数据格式的系统能够与 Prometheus 监控系统集成。

功能
  数据接收:graphite_exporter在指定的端口上监听传入的Graphite数据。当有其他系统或服务将监控数据发送到该端口时,graphite_exporter能够接收这些数据。

  数据转换:graphite_exporter能够将接收到的Graphite数据格式(通常是使用plaintext协议传输的以点(.)分隔的度量标准)转换为Prometheus期望的exposition format(即Prometheus可以理解和抓取的格式)。这样,原本只能发送Graphite格式数据的系统或服务就能与Prometheus兼容。

  指标映射:由于Graphite和Prometheus在指标命名和组织结构上有所不同,graphite_exporter通常提供映射功能,允许用户定义如何将Graphite的指标路径映射到Prometheus的指标名称和标签。这确保了转换后的数据在Prometheus中具有合适的结构和语义。

应用场景
  监控系统集成:当企业已经存在基于Graphite的监控系统,并希望将其集成到Prometheus中时,Graphite Exporter扮演了桥梁的角色。它允许企业保留现有的监控数据源,同时利用Prometheus的强大功能进行数据分析和告警。

  指标补充:在某些情况下,核心的Prometheus Exporter(如Node Exporter)可能不包含所有需要的监控指标。这时,Graphite Exporter可以用来补充这些缺失的指标,提供更全面的监控视图。

  迁移与过渡:对于正在从Graphite迁移到Prometheus的组织,Graphite Exporter可以作为一个临时的解决方案,在迁移过程中确保数据的连续性和可比性。

二、安装graphite_exporter💾

注意事项和常见问题
  1.环境配置:确保操作系统满足Graphite Exporter的要求。检查是否有足够的磁盘空间和内存。

  2.依赖安装:确认已安装所有必要的依赖项,如合适的Python版本(如果Graphite Exporter是用Python编写的)。根据安装指南,预先安装可能需要的库或工具。

  3.网络配置:确保服务器防火墙设置允许Graphite Exporter的监听端口(默认为9109)对外开放。如果Exporter将部署在云环境或受限制的网络中,请配置相应的网络策略和安全组规则。

  4.配置文件:仔细检查配置文件,确保所有参数都正确设置,特别是映射关系(如果需要)。验证配置中的端口号、地址和其他相关设置是否与现有环境相匹配。

  5.权限问题:确保运行Graphite Exporter的用户有足够的权限来访问必要的文件和目录。如果Exporter需要监听低于1024的端口,可能需要以root权限运行。

2.1 访问graphite_exporter官方网站 🌐

  • 打开浏览器,访问graphite_exporter的官方下载页面,通常位于Prometheus官方网站的子目录下:https://github.com/prometheus/graphite_exporter/releases

2.2 选择适合的版本🔍

  • 在下载页面,你将看到不同操作系统的graphite_exporter二进制包。根据你的操作系统选择适合的版本。例如,如果你使用的是Linux 64位系统,就选择graphite_exporter-0.15.0.linux-amd64.tar.gz(其中x.x.x是版本号)。

2.3 下载graphite_exporter⬇️

  • 点击所选版本的下载链接,将graphite_exporter的二进制包下载到你的本地计算机。

2.4 解压安装包📂

  • 将下载的graphite_exporter压缩包解压到你想要安装的目录。你可以使用命令行工具(如tar)来完成这个步骤。解压后,你将看到一个名为graphite_exporter-x.x.x.linux-amd64的目录,其中包含graphite_exporter的二进制文件和其他相关文件。
tar -xzf graphite_exporter-x.x.x.linux-amd64.tar.gz

2.5 运行graphite_exporter🚀

  • 进入解压后的目录,并运行graphite_exporter服务器。在Linux下,你可以使用如下命令。如果一切正常,你应该能在终端看到graphite_exporter的启动日志。
cd graphite_exporter-x.x.x.linux-amd64./graphite_exporter

三、graphite_exporter指标和配置详解📖

3.1 graphite_exporter_mapping

# 示例文件
mappings:
- match: test.dispatcher.*.*.*name: dispatcher_events_totallabels:action: $2job: test_dispatcheroutcome: $3processor: $1- match: '*.signup.*.*'name: signup_events_totallabels:job: ${1}_serveroutcome: $3provider: $2- match: 'servers\.(.*)\.networking\.subnetworks\.transmissions\.([a-z0-9-]+)\.(.*)'match_type: regexname: 'servers_networking_transmissions_${3}'labels: hostname: ${1}device: ${2}
  • mappings
    • match: test.dispatcher.*.*.
        用于匹配传入的度量名称。它可以是简单的通配符模式(如.signup..)或使用正则表达式(如servers.(.*).networking.subnetworks.transmissions.([a-z0-9-]+).(.*))。在此示例中,匹配以test.dispatcher开头的度量名,后面跟着任意三个由点分隔的组件。
    • name
        重新映射后的度量名称。可以在其中插入变量(如${1}, ${2}, ${3}等),这些变量对应于match模式中捕获的组。在这个例子表示所有匹配的度量都将被重命名为dispatcher_events_total。
    • labels
        一个键值对的集合,用于定义与度量相关联的标签。这些标签提供了关于度量的额外上下文信息。标签的值也可以是变量,这些变量根据match模式中的捕获组进行替换。
      • action: $2:将match模式中的第二个捕获组(在这里是*)作为action标签的值。
      • job: test_dispatcher:为所有匹配的度量添加一个固定的job标签,值为test_dispatcher。
      • outcome: $3 和 processor: $1:类似地,它们分别使用match模式中的第三和第一个捕获组作为标签的值。

  • 例如将指标转换为 Prometheus 指标,遵循:
test.dispatcher.FooProcessor.send.success=> dispatcher_events_total{processor="FooProcessor", action="send", outcome="success", job="test_dispatcher"}foo_product.signup.facebook.failure=> signup_events_total{provider="facebook", outcome="failure", job="foo_product_server"}test.web-server.foo.bar=> test_web__server_foo_bar{}servers.rack-003-server-c4de.networking.subnetworks.transmissions.eth0.failure.mean_rate=> servers_networking_transmissions_failure_mean_rate{device="eth0",hostname="rack-003-server-c4de"}

3.2 graphite_exporter.service

  • - -web.telemetry-path=“/metrics”
      指定Prometheus抓取metrics的路径。默认情况下,Prometheus会在/metrics路径上抓取数据,但你可以通过此参数更改它。
  • - -graphite.listen-address=:9109
      设置graphite_exporter监听Graphite度量数据的地址和端口。在这个例子中,它监听所有IPv4和IPv6地址的9109端口。你可以更改地址和端口以适应你的网络环境。
  • - -graphite.mapping-config=“”
      通过这个参数,你可以指定一个映射配置文件,定义如何将接收到的Graphite度量指标映射到Prometheus的度量指标。如果你不提供这个文件,graphite_exporter将使用默认的映射规则。
  • - -graphite.sample-expiry=5m
      定义接收到的Graphite度量样本在内存中未被Prometheus抓取之前可以保留多长时间。超过设定的时间后,这些样本将被丢弃。在这个例子中,样本的过期时间设置为5分钟。
  • - -[no-]graphite.mapping-strict-match
      如果启用此选项,只有当Graphite度量指标与映射配置中的某个规则完全匹配时,才会被导出到Prometheus。如果没有匹配的规则,该度量指标将被忽略。
  • - -graphite.cache-size=1000
      用于设置存储接收到的Graphite度量数据的内部缓存的大小,在这个例子中,缓存大小设置为1000个样本。
  • - -graphite.cache-type=lru
      设置缓存类型。LRU(Least Recently Used)是一种常见的缓存替换策略,当缓存满时,会淘汰最近最少使用的数据。
  • - -debug.dump-fsm=“”
      用于调试目的。如果提供了文件路径,exporter会将有限状态机(Finite State Machine)的当前状态定期转储到该文件,有助于开发者理解exporter的内部状态。
  • - -[no-]check-config
      如果启用此选项,exporter将在启动时检查配置文件的正确性,并在发现错误时退出。
  • - -[no-]web.systemd-socket
      如果你的服务是通过systemd的socket激活功能管理的,可以启用这个选项。这样,graphite_exporter将不会自己监听端口,而是使用由systemd提供的socket。
  • - -web.listen-address=:9108
      设置exporter的HTTP服务监听的地址和端口,Prometheus将从这个地址抓取metrics数据。
  • - -web.config.file=“”
      指定Web服务的配置文件路径。

四、实战演练:生产环境搭建指南🔨

4.1 创建普通用户管理graphite_exporter👤

useradd deploy

4.2 解压graphite_exporter.tar.gz📦

注意:
  我的是x86,所以使用graphite_exporter-0.15.0.linux-amd64.tar.gz,您可以使用uname -a命令查看系统架构

tar xvf graphite_exporter-0.15.0.linux-amd64.tar.gz -C /home/deploy/

4.3 将graphite_exporter集成到Prometheus配置中✂️

  将graphite_exporter集成到Prometheus配置中,确保数据能够正常采集。编辑Prometheus的配置文件(通常是prometheus.yml),在scrape_configs部分添加graphite_exporter的配置。告诉Prometheus将采集localhost:9108的数据。

  - job_name: 'graphite_exporter'static_configs:- targets:- targets: ["localhost:9108"]labels:exporter: graphite_exporter

4.4 更改graphite_exporter软件包名称✂️

mv graphite_exporter-0.15.0.linux-amd64 /home/deploy/graphite_exporter

4.5 编辑graphite_exporter.service文件📝

cat > /etc/systemd/system/graphite_exporter.service <<EOF
[Unit]
Description=Graphite Exporter
After=network.target[Service]
Type=simple
User=deploy
Group=deploy
ExecStart=/home/deploy/graphite_exporter/graphite_exporter \
--graphite.mapping-config=/home/deploy/graphite_exporter/graphite_exporter_mapping \
--graphite.sample-expiry=5m \
--graphite.mapping-strict-match \
--graphite.listen-address=:9109 \
--web.listen-address=:9108
ExecReload=/bin/kill -HUP
Restart=on-failure[Install]
WantedBy=multi-user.target
EOF

4.6 启动graphite_exporter.service🔌

sudo systemctl daemon-reloadsudo systemctl enable --now graphite_exporter.service

4.7 查看服务是否正常启动🔍

# 查看service服务是否启动
sudo systemctl status graphite_exporter.service# 查看端口是否存在
sudo ss -ntulp | grep -E '9108|9109'

相关资料下载地址📚

  • 官方文档:https://prometheus.io/docs/introduction/overview/
  • 下载地址:https://github.com/prometheus/prometheus/releases/tag/v2.52.0
  • 文档地址:https://prometheus.io/docs/prometheus/latest/installation/
  • 离线包下载链接:https://pan.baidu.com/s/1ANF_AlFnM5_FMIbKBuzBmg 提取码:yqpt

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

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

相关文章

Vue3中的常见组件通信之props和自定义事件

Vue3中的常见组件通信 概述 ​ 在vue3中常见的组件通信有props、mitt、v-model、 r e f s 、 refs、 refs、parent、provide、inject、pinia、slot等。不同的组件关系用不同的传递方式。常见的撘配形式如下表所示。 组件关系传递方式父传子1. props2. v-model3. $refs4. 默认…

Python课设-学生信息管理系统

一、效果展示图 二、前端代码 1、HTML代码 <1>index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0">…

安卓模拟鼠标,绘图板操作电脑PC端,卡卡罗特也说好,儿童节快乐

家人们&#xff0c;上链接了&#xff1a;https://download.csdn.net/download/jasonhongcn/89387887

B站如何屏蔽短视频:成都鼎茂宏升文化传媒公司

B站如何屏蔽短视频&#xff1a;优化你的观看体验 在当今数字化时代&#xff0c;B站&#xff08;哔哩哔哩&#xff09;作为国内领先的弹幕视频网站&#xff0c;以其丰富的视频资源和独特的弹幕文化吸引了大量用户。然而&#xff0c;随着短视频的兴起&#xff0c;B站也引入了短视…

intel深度相机D455的使用

一、D455介绍 Intel RealSense D455 是RealSense D400系列的一部分&#xff0c;这个系列的设备以其高精度和可靠性而闻名。D455相比于之前的型号&#xff08;如D415和D435&#xff09;&#xff0c;提供了更远的感知范围和更高的精度。 二、使用代码 我们先定义一下相关的函数…

鸿蒙OS初识

学习官网&#xff1a;https://www.harmonyos.com/cn/develop 准备 注册&#xff0c;安装软件&#xff08;node:12, DevEco Studio&#xff09;&#xff1a; https://developer.harmonyos.com/cn/docs/documentation/doc-guides/software_install-0000001053582415#ZH-CN_TOP…

MFC3d立体按钮制作

1、本程序基于前期我的博客文章MFC用CButtonST类实现图片透明按钮(免费源码下载) 2、添加CeXDib.cpp CeXDib.h ShadeButtonST.cpp ShadeButtonST.h到项目文件夹下&#xff0c;和FileView中如图。 3、在ButtonShadeDlg.h中添加代码 #include "ShadeButtonST.h" #in…

Qml开发的两种方法

一.Qml开发的两种方法 1.Qt Creator 开发,手动编写qml代码 这种方法开发很方便&#xff0c;适合对qml语言非常熟悉的开发人员。 2.用Qt Design Studio 设计qml界面 这种方法更适合对qml不太熟悉的人&#xff0c;可以实现qml控件的拖拉拽&#xff0c;类似与widget界面开发&…

【原型模式】详解

一.概念 原型模式是一种创建型设计模式&#xff0c;它的主要思想是通过复制现有对象来创建新对象&#xff0c;而不是通过实例化一个类来创建。在原型模式中&#xff0c;我们称被复制的对象为原型&#xff08;Prototype&#xff09;&#xff0c;新创建的对象为克隆体&#xff0…

用户画像知识点补充——多数据源

引入 针对用户画像项目来说&#xff08;产品&#xff09;必须要支持从多种数据源加载业务数据&#xff0c;构建用户标签。 在之前的标签模型开发中&#xff0c;主要是为了简化开发复杂度&#xff0c;业务数据统一存储到HBase表中。 数据源包含如下几个方面&#xff1a; 存储H…

【应用层】 DNS 域名协议解析

文章目录 DNS(Domain Name System)出现及演化 ⏳DNS 概括&#x1f50d;DNS定义DNS 作用 DNS工作原理⚙️域名解析DNS解析的详细工作流程 DNS域名解析方式&#x1f504;静态DNS域名解析动态DNS域名解析 DNS域名解析过程的深入分析 &#x1f9d0;递归查询迭代查询 公共DNS服务器的…

STC8增强型单片机进阶开发--LED呼吸灯(PWM)

知不足而奋进 望远山而前行 文章目录 目录 文章目录 前言 目标 内容 PWM基础概念 STC8H芯片 PWMA应用 PWM配置详解 周期 占空比 模式 使能PWM 引脚配置 EAXSFR扩展寄存器 总结 前言 学习PWM&#xff08;脉宽调制&#xff09;是探索数字信号转模拟信号的重要一步&#xff0c;尤…

ad18学习笔记21:焊盘设置Paste Mask Expansion(锡膏层延伸)

在pcb上放置焊盘的时候&#xff0c;可以对焊盘进行设置&#xff0c;可以用默认的规则&#xff0c;可以用自定义的规则&#xff0c;网上很少看到自定义的规则怎么用。 参考了官方的说明文档&#xff0c;我只是稍微补充了一下 paste mask与solder mask有哪些区别_paste mask与s…

终于更新了!时隔一年niushop多商户b2b2c的新补丁v5.0.2终于发布了,一起看看有啥新变化

注意这是最新版的V5.02_多商户V5.0.2版本更新说明 瞧瞧更新了什么内容&#xff0c; 优化功能 优化手机号、身份证等常用验证规则&#xff0c;全局化处理优化商品列表接口查询速度 修复功能修复系统内部分图片上传功能调用接口跨端口问题修复总后台和商家后台订单管理搜索标签在…

一文彻底讲透 PyTorch

节前&#xff0c;我们组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、今年参加社招和校招面试的同学。 针对大模型技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备面试攻略、面试常考点等热门话题进行了深入的讨论。 汇总合集…

JQC-3FF-S-Z 继电器模块使用(arduino)

前言 继电器模块可以控制电流的接通和非接通状态&#xff0c;和开关一样。实际上是用小电流去控制大电流运作的一种“自动开关” 本文只是简单使用继电器模块做一个 led 点亮和熄灭的案例&#xff0c;结合案例可以和 nodemcu 等板子结合做出远程控制开关。 材料准备 杜邦线…

无限可能LangChain——构建一个简单的LLM应用程序

在本快速入门中&#xff0c;我们将向您展示如何构建一个简单的LLM应用程序。该应用程序将文本从英语翻译成另一种语言。这是一个相对简单的LLM应用程序——它只是一个LLM调用加上一些提示。尽管如此&#xff0c;这仍然是开始使用LangChain的好方法——只需一些提示和一个LLM调用…

小波相干性显著性检验(MATLAB R2018A)

交叉小波常被用于检测不同信号之间的相关性&#xff0c;其在时频域建立了不同信号之间的联系。对于两个时域信号&#xff0c;其交叉小波变换和交叉小波尺度谱如下&#xff1a; 以轴承振动信号为例&#xff0c;利用正常轴承与故障轴承的振动信号、故障轴承和故障轴承的振动信号分…

【JavaEE进阶】——Mybatis操作数据库(使用注解和XML方式)

目录 &#x1f6a9;三层架构 &#x1f388;JDBC操作回顾 &#x1f6a9;什么是MyBatis &#x1f6a9;MyBatis⼊⻔ &#x1f388;准备工作 &#x1f4dd;创建⼯程 &#x1f4dd;数据准备 &#x1f388;配置数据库连接字符串 &#x1f388;写持久层代码 &#x1f388;单…

插入排序(直接插入排序、折半插入排序、希尔排序)的性能分析

目录 前言 插入排序 直接插入排序性能分析 折半插入排序性能分析 希尔排序性能分析 前言 本篇文章主要是总结插入排序的性能分析&#xff0c;具体的概念、算法、排序过程&#xff0c;我前面的文章有写&#xff0c;在这里就不再过多赘述了。 插入排序 插入排序是一种简单直…