千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:武汉千锋IT培训  >  技术干货  >  从部署到监控快速搭建自己的Prometheus监控系统

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

来源:千锋教育
发布人:xqq
时间: 2023-12-27 22:37:23

从部署到监控:快速搭建自己的 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 时遇到了问题,请到官方文档中查找帮助或联系社区成员。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

Golang高效编写大规模数据处理使用协程优化分布式计算

2023-12-27

OpenStack云平台高可用设计,为你的业务保驾护航!

2023-12-26

云计算环境下如何实现高并发、高可用的负载均衡设计

2023-12-26

最新文章NEW

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

2023-12-27

Golang与Kubernetes打造强大的容器编排系统

2023-12-27

如何在云计算环境中实现数据安全备份和恢复,确保业务连续性

2023-12-27

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>