• 每日一库:Prometheus


    什么是 Prometheus

    Prometheus 是一个开源的系统监控和警报工具,最初由 SoundCloud 开发,并于 2012 年发布为开源项目。它是一个非常强大和灵活的工具,用于监控应用程序和系统的性能,并根据预定义的规则触发警报。以下是对 Prometheus 的详细介绍:

    特点和优势:

    1. 多维数据模型: Prometheus 使用多维数据模型来存储时间序列数据。每个时间序列都由一组键值对唯一标识,这使得数据非常灵活且容易查询。
    2. 灵活的查询语言: Prometheus 使用一种称为 PromQL(Prometheus Query Language)的查询语言,允许用户执行复杂的查询和数据分析操作。你可以使用 PromQL 从存储的度量数据中提取有价值的信息。
    3. 内置 Web UI: Prometheus 提供了一个内置的 Web 用户界面,用于查询和可视化度量数据。这个用户界面使得用户能够更直观地查看数据,而无需编写查询语言。
    4. 持久性存储: Prometheus 使用本地存储引擎来保存时间序列数据,这使得它能够高效地存储大量数据,并且不需要依赖外部数据库。它还支持数据快照和备份。
    5. 警报和通知: Prometheus 具有强大的警报功能,允许用户定义警报规则,当某些条件满足时触发警报。警报可以发送到各种通知渠道,如电子邮件、Slack 等。
    6. 自动发现: Prometheus 支持服务自动发现,可以自动发现并监控新的目标(如容器、虚拟机等)。这使得在动态环境中维护监控系统变得更容易。
    7. 社区支持和生态系统: Prometheus 拥有一个活跃的社区,以及丰富的插件和集成,可与其他工具和服务(如Grafana、Alertmanager、Kubernetes等)集成。

    Prometheus 架构:

    Prometheus 由以下几个核心组件组成:

    1. Prometheus 服务器(Prometheus Server): 这是主要的后端组件,负责抓取和存储时间序列数据,执行查询和计算度量数据。
    2. Exporters: 这些是用于将应用程序和系统度量数据公开为 Prometheus 可以抓取的时间序列的代理。Prometheus 社区维护了许多 Exporter,用于监控各种常见的服务和应用程序。
    3. Client Libraries: Prometheus 提供各种语言的客户端库,允许应用程序开发者轻松将度量数据暴露给 Prometheus。这些库可用于记录自定义应用程序指标。
    4. Alertmanager: 这是用于处理警报的组件。它负责根据预定义的规则管理和分发警报,可以将警报发送到不同的通知渠道。

    Prometheus 工作流程:

    1. 数据抓取: Prometheus 定期轮询配置的目标,如应用程序和 Exporters,以获取度量数据。这些数据以时间序列的形式存储在 Prometheus 内部数据库中。
    2. 数据存储: Prometheus 使用内置的本地存储引擎将时间序列数据持久化存储在本地磁盘上。存储数据的持久性使得用户可以访问历史数据以进行分析。
    3. 查询和分析: 用户可以使用 PromQL 查询语言执行各种查询和分析操作,以从存储的度量数据中提取有用的信息。查询结果可以在 Prometheus Web 用户界面中查看。
    4. 警报和通知: 用户可以定义警报规则,当某些条件满足时,Prometheus 将触发警报。Alertmanager

    使用 Prometheus 监控应用程序

    下面是关于如何在 Go 中使用 Prometheus 的详细介绍:

    步骤1:安装 Prometheus

    首先,你需要安装和配置 Prometheus 服务器。你可以从 Prometheus 的官方网站下载适合你操作系统的二进制文件,并根据官方文档配置 Prometheus 服务器。安装完成后,启动 Prometheus 服务器。

    步骤2:引入 Prometheus Go 客户端库

    Prometheus 提供了一个用于 Go 应用程序的客户端库,你需要引入这个库以便在应用程序中生成度量数据。你可以使用 Go 模块来引入 Prometheus Go 客户端库:

    go get github.com/prometheus/client_golang/prometheus
    go get github.com/prometheus/client_golang/promhttp

    步骤3:创建度量指标

    在你的 Go 应用程序中,你需要创建要监控的度量指标。Prometheus 支持多种度量类型,包括计数器(Counter)、测量仪(Gauge)和直方图(Histogram)等。以下是一些示例:

    创建计数器(Counter):

    import (
    "github.com/prometheus/client_golang/prometheus"
    )
    var requestsTotal = prometheus.NewCounter(
    prometheus.CounterOpts{
    Name: "myapp_requests_total",
    Help: "Total number of requests",
    },
    )
    func init() {
    prometheus.MustRegister(requestsTotal)
    }

    创建测量仪(Gauge):

    import (
    "github.com/prometheus/client_golang/prometheus"
    )
    var freeMemory = prometheus.NewGauge(
    prometheus.GaugeOpts{
    Name: "myapp_free_memory",
    Help: "Free memory in bytes",
    },
    )
    func init() {
    prometheus.MustRegister(freeMemory)
    }

    步骤4:导出度量数据

    要使 Prometheus 能够收集应用程序生成的度量数据,你需要创建一个 HTTP 处理程序来暴露这些数据。通常,Prometheus 使用 /metrics 路径来获取度量数据。

    import (
    "net/http"
    "github.com/prometheus/client_golang/promhttp"
    )
    func main() {
    http.Handle("/metrics", promhttp.Handler())
    http.ListenAndServe(":8080", nil)
    }

    步骤5:生成和导出度量数据

    在你的应用程序中,使用创建的度量指标来生成和更新度量数据。例如,如果你想增加请求数计数器的值,可以执行以下操作:

    requestsTotal.Inc()

    Prometheus 会定期轮询你的应用程序的 /metrics 路径,以获取最新的度量数据。

    步骤6:配置 Prometheus 服务器

    在 Prometheus 服务器的配置文件中,添加你的应用程序的终端(即要抓取度量数据的地址):

    scrape_configs:
    - job_name: 'myapp'
    static_configs:
    - targets: ['your_app_host:8080']

    步骤7:查询和可视化

    启动 Prometheus 服务器后,你可以访问 Prometheus Web UI(默认地址为 http://localhost:9090 ),使用 PromQL 查询语言来查询和可视化度量数据。

    步骤8:设置报警规则

    Prometheus 还支持设置报警规则,以便在达到某些条件时触发警报。你可以在 Prometheus 配置文件中定义这些规则。

    以上就是使用 Prometheus 在 Go 应用程序中进行监控的基本步骤。通过创建自定义的度量指标并将其导出到 Prometheus,你可以轻松地监控和分析你的应用程序性能。同时,Prometheus 提供了丰富的查询和可视化工具,可以帮助你更好地理解应用程序的行为和趋势。


    孟斯特

    声明:本作品采用署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)进行许可,使用时请注明出处。
    Author: mengbin
    blog: mengbin
    Github: mengbin92
    cnblogs: 恋水无意


  • 相关阅读:
    JavaScript获取DOM元素相关信息和属性
    iOS开发-WKWebView加载微信H5支付
    数据结构与算法基础-学习-35-各排序算法效率总结
    【C语言深入理解指针(4)】
    深入了解视觉语言模型
    使用android studio将h5项目打包成安卓app
    Spring Cloud【SkyWalking日志、SkyWalking告警 、Skywalking自定义告警规则】(十五)
    Redis实践记录与总结
    React+TypeScript 声明组件的属性和默认值
    【计算机视觉】24-Object Detection
  • 原文地址:https://www.cnblogs.com/lianshuiwuyi/p/17708818.html