全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货  >  详情

从部署到监控快速搭建自己的Prometheus监控系统

来源:千锋教育
发布人:xqq
2023-12-27

推荐

在线提问>>

从部署到监控:快速搭建自己的 Prometheus 监控系统

随着互联网技术的发展,监控系统越来越重要。在一次紧急排查中,我发现我们的系统没有监控,导致难以分析问题。因此,我学习了一下 Prometheus 监控系统,并写下这篇文章以帮助需要的人快速搭建自己的监控系统。

什么是 Prometheus?

Prometheus 是一款开源的监控系统。它的特点是易于部署、易于操作、易于扩展、支持多维度数据收集和灵活的查询语言。从架构上来说,它采用 pull 模型,不需要使用者编写采集指标的代码。另外,Prometheus 社区提供了一些 Exporter,用于采集各类应用和设备的数据。最后,Prometheus 提供了一些可视化工具,如 Grafana 和 Alertmanager。

如何部署 Prometheus?

Prometheus 可以在各种环境中运行,如 Docker、Kubernetes 和虚拟机。但为了保持简洁,这篇文章只介绍基于 Docker 和 Docker Compose 的部署方式。

首先,你需要在你的机器上安装 Docker 和 Docker Compose。然后,你需要创建一个 Docker Compose 文件,如下所示:

version: '3'

services:

prometheus:

image: prom/prometheus:v2.23.0

container_name: prometheus

restart: always

ports:

- "9090:9090"

volumes:

- ./prometheus.yml:/etc/prometheus/prometheus.yml

command:

- --config.file=/etc/prometheus/prometheus.yml

上述配置文件中,我们使用了官方提供的 Prometheus 镜像,并将镜像暴露在 9090 端口。我们还将它的配置文件挂载到了我们本地目录中。在该配置文件中,你需要指定你要采集的应用或设备的 Exporter 的地址。

为了启动该服务,你只需在该 Docker Compose 文件所在目录下运行以下命令:

$ docker-compose up -d

如何配置 Exporter?

在 Prometheus 的配置文件中,你需要指定你要采集的 Exporter 的地址。在本文中,我们以 Node Exporter 为例。Node Exporter 是一个针对 Linux 系统的 Exporter,用于采集系统级别的指标。

使用以下命令下载 Node Exporter:

$ wget https://github.com/prometheus/node_exporter/releases/download/v1.2.2/node_exporter-1.2.2.linux-amd64.tar.gz

解压文件并启动 Node Exporter:

$ tar -xvf node_exporter-1.2.2.linux-amd64.tar.gz

$ cd node_exporter-1.2.2.linux-amd64

$ ./node_exporter

现在,你可以在 Prometheus 的配置文件中添加以下内容:

- job_name: 'node_exporter'

static_configs:

- targets: ['localhost:9100']

上述内容中,我们使用了 static_configs 类型,指定了要采集的主机的地址。

如何查询指标?

Prometheus 使用 PromQL 语言进行查询。以下是一些常见的查询:

- 查询 CPU 使用率:100 - (avg by(instance)(irate(node_cpu_seconds_total{mode='idle'}[5m])) * 100)

- 查询内存使用率:(node_memory_MemTotal - node_memory_MemFree - node_memory_Buffers - node_memory_Cached) / node_memory_MemTotal * 100

- 查询磁盘使用率:(node_filesystem_size_bytes - node_filesystem_free_bytes) / node_filesystem_size_bytes * 100

如何可视化?

Prometheus 提供了一些可视化工具,如 Grafana 和 Alertmanager。这里,我们以 Grafana 为例,展示如何使用该工具来可视化指标。

首先,你需要下载 Grafana:

$ docker run -d --name=grafana -p 3000:3000 grafana/grafana

然后,你需要在 Grafana 的界面中添加 Prometheus 数据源,并创建一个 Dashboard。你可以使用上述查询语言来创建 Panel,并使用 Prometheus 的标签来进行聚合。

最后,你可以使用 Alertmanager 来发送报警并集成到你的监控系统中。

结论

在本文中,我们介绍了如何快速搭建自己的 Prometheus 监控系统,并展示了如何配置 Exporter、查询指标和可视化数据。如果你在使用 Prometheus 时遇到了问题,请到官方文档中查找帮助或联系社区成员。

相关文章

从Docker到Kubernetes容器技术的演进之路

从部署到监控快速搭建自己的Prometheus监控系统

AI技术在网络安全中的应用:如何提高网络安全防护水平?

从攻击事件看网络安全:利用大数据分析来升级企业安全防护

浅析加密算法:RSA、AES、DES等主流加密技术解析

开班信息 更多>>

课程名称
全部学科
咨询

HTML5大前端

Java分布式开发

Python数据分析

Linux运维+云计算

全栈软件测试

大数据+数据智能

智能物联网+嵌入式

网络安全

全链路UI/UE设计

Unity游戏开发

新媒体短视频直播电商

影视剪辑包装

游戏原画

    在线咨询 免费试学 教程领取