构建 Prometheus + Thanos 环境时,考虑到 Prometheus 原生开源版并未提供高可用性的支持,特别是在面对更大规模和高可用性要求的监控场景时。因此,引入 Thanos 成为一种选择。Prometheus 通常以单实例运行,适用于小到中等规模的监控需求,但在更大规模和高可用性要求下,Thanos 提供了解决方案,通过集中、查询汇聚多个 Prometheus 实例的数据,并支持长期数据存储,从而提高了整体可用性。

本系列将探讨 Thanos 的常用组件,介绍它们的功能和作用:

通过了解每个组件的应用机制和应用配置,为监控系统的构建和维护提供更有力的保证。

1 概述 && 架构

1.1 说明

为了实现整个 Prometheus 监控系统的统一查询入口,并将历史数据进行一致性存储,示例采用 Thanos 构建解决方案。该方案具备以下特点:

  1. 提供 Prometheus 的统一查询入口和历史数据的一致性保存。

  2. Thanos Querier 兼容 Prometheus 接口,使 Grafana 能够直接利用 Prometheus 数据源进行监控。

  3. Thanos 包含以下组件:

  • Sidecar:作为 Prometheus 收集器的代理,负责数据的中转和收集;
  • Querier:通过 Querier 可以聚合各个 Sidecar 的数据,实现统一的查询功能;
  • Store: 将收集回来的数据存储到对象存储或其他备份与归档类存储中;
  • Compactor: 负责对存储在对象存储中的数据进行压缩;
  • Ruler: 统一告警规则与阈值配置;

通过 Thanos + Prometheus 的部署,客户将构建一个分布式的查询和持久性存储功能的 Prometheus 监控系统。

1.2 基础架构图

2 环境部署

2.1 初始化配置

# 修改打开文件数
cat >> /etc/security/limits.conf << EOF
* soft nofile 65535
* hard nofile 65535
* soft nproc 65535
* hard nproc 65535 
EOF

# 禁用 selinux && 禁用 firewalld
setenforce 0 && sed -i 's/^SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config && getenforce
systemctl disable firewalld && systemctl stop firewalld


# 停止 swap, fstab 关闭 swap 自启动 
swapoff -a
vim /etc/fstab

# 创建 Prometheus 用户
useradd -s /sbin/nologin prometheus

# 创建 Prometheus 存储目录
/data/prometheus

2.2 Prometheus 部署

2.2.1 下载 & 安装 Prometheus

# 下载 Prometheus
wget https://github.com/prometheus/prometheus/releases/download/v2.45.0/prometheus-2.45.0.linux-amd64.tar.gz

# 解压 Prometheus
tar xf prometheus-2.45.0.linux-amd64.tar.gz

# 移动到工具目录
mv prometheus-2.45.0.linux-amd64 /usr/local/prometheus

# 配置 Prometheus 权限

chown prometheus.prometheus -R /usr/local/prometheus/

chown prometheus.prometheus -R /data/prometheus

2.2.2 Prometheus 服务配置

# vim /etc/systemd/system/prometheus.service

[Unit]
Description=Prometheus Server
Documentation=https://prometheus.io/docs/introduction/overview/
After=network-online.target

[Service]
User=prometheus
Group=prometheus
Restart=on-failure
ExecStart=/usr/local/prometheus/prometheus \
  --config.file=/usr/local/prometheus/prometheus.yml \
  --storage.tsdb.path=/data/prometheus \
  --storage.tsdb.min-block-duration=2h \
  --storage.tsdb.max-block-duration=2h \
  --web.enable-admin-api \
  --web.enable-lifecycle \

[Install]
WantedBy=multi-user.target

2.2.3 Prometheus 启动 && 开机启动

systemctl start prometheus.service
systemctl enable prometheus.service

3. 参考资料

Prometheus 安装包

Download | Prometheus


 

🚀 炸鸡物料库 🚀

🔍 内容定位: IT技术领域,云计算、云原生、DevOps 和 AI 等相关的技术资讯、实践和经验分享。面向开发、系统和云计算,提供实用的技术内容。

🎯 目标受众: 面向开发者、系统管理员和云计算从业者,提供实用的技术内容。

🗓️ 更新频率:每周更新,每次分享都为您带来有价值的技术内容。

🤝 互动与反馈: 鼓励读者留言、评论,有问题随时提问,我们将积极互动并提供帮助。

💌 订阅方式: 扫描二维码或搜索“炸鸡物料库”关注,不错过每一篇精彩内容。

🌐 合作与分享: 如果您有技术分享或合作计划,欢迎联系我们,共同成长!

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐