K8S学习之基础三十五:k8s之Prometheus部署模式

Prometheus 有多种部署模式,适用于不同的场景和需求。以下是几种常见的部署模式:

1. 单节点部署

这是最简单的部署模式,适用于小型环境或测试环境。

特点:
  • 单个 Prometheus 实例负责所有的数据采集、存储和查询。
  • 配置简单,易于维护。
  • 不具备高可用性和扩展性。
适用场景:
  • 小型项目或测试环境。
  • 对高可用性要求不高的场景。
部署步骤:
  1. 下载并解压 Prometheus。
  2. 配置 prometheus.yml
  3. 启动 Prometheus。

bash

复制

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

2. 高可用部署(HA)

为了提高系统的可用性和容错能力,可以使用高可用部署模式。

特点:
  • 多个 Prometheus 实例同时运行,采集相同的数据。
  • 通过负载均衡器分发查询请求。
  • 具备高可用性,单个实例故障不会影响整体服务。
适用场景:
  • 对高可用性要求较高的生产环境。
  • 需要确保监控系统持续可用的场景。
部署步骤:
  1. 部署多个 Prometheus 实例,配置相同的 prometheus.yml
  2. 使用负载均衡器(如 Nginx、HAProxy)分发查询请求。
  3. 配置 Alertmanager 处理告警。

yaml

复制

# prometheus.yml 示例
global:scrape_interval: 15sscrape_configs:- job_name: 'prometheus'static_configs:- targets: ['localhost:9090']

3. 联邦部署(Federation)

联邦部署模式适用于大规模分布式系统,通过分层采集和汇总数据。

特点:
  • 多个 Prometheus 实例分别采集不同区域或服务的数据。
  • 一个中心 Prometheus 实例从其他实例中采集汇总数据。
  • 适用于大规模、分布式环境。
适用场景:
  • 大规模分布式系统。
  • 需要分区域或分服务采集数据的场景。
部署步骤:
  1. 部署多个 Prometheus 实例,分别采集不同区域或服务的数据。
  2. 配置中心 Prometheus 实例,从其他实例中采集汇总数据。

yaml

复制

# 中心 Prometheus 配置示例
scrape_configs:- job_name: 'federate'scrape_interval: 15shonor_labels: truemetrics_path: '/federate'params:'match[]':- '{job="prometheus"}'- '{__name__=~"job:.*"}'static_configs:- targets:- 'source-prometheus-1:9090'- 'source-prometheus-2:9090'

4. 分片部署(Sharding)

分片部署模式通过将数据采集任务分散到多个 Prometheus 实例,适用于超大规模环境。

特点:
  • 多个 Prometheus 实例分别负责不同的数据采集任务。
  • 通过分片策略(如哈希分片)分配采集任务。
  • 适用于超大规模、高并发的环境。
适用场景:
  • 超大规模系统,单个 Prometheus 实例无法处理所有数据。
  • 需要高并发采集和存储的场景。
部署步骤:
  1. 部署多个 Prometheus 实例,配置不同的 prometheus.yml
  2. 使用分片策略(如哈希分片)分配采集任务。
  3. 配置中心 Prometheus 实例或查询层(如 Thanos)汇总数据。

yaml

复制

# 分片 Prometheus 配置示例
global:scrape_interval: 15sscrape_configs:- job_name: 'sharded_job'static_configs:- targets: ['target1:9100', 'target2:9100']relabel_configs:- source_labels: [__address__]modulus: 2target_label: __tmp_hashaction: hashmod- source_labels: [__tmp_hash]regex: '0'action: keep

5. 使用 Thanos 或 Cortex 的分布式部署

Thanos 和 Cortex 是 Prometheus 的扩展项目,提供了分布式存储和查询能力。

特点:
  • 提供全局视图和长期存储能力。
  • 支持高可用性和水平扩展。
  • 适用于大规模、长期存储和查询的场景。
适用场景:
  • 需要长期存储监控数据的场景。
  • 需要全局视图和高可用性的场景。
部署步骤:
  1. 部署多个 Prometheus 实例,配置相同的 prometheus.yml
  2. 部署 Thanos 或 Cortex 组件(如 Sidecar、Store Gateway、Querier 等)。
  3. 配置 Thanos 或 Cortex 的全局视图和长期存储。

yaml

复制

# Thanos Sidecar 配置示例
apiVersion: apps/v1
kind: Deployment
metadata:name: prometheus
spec:replicas: 1template:spec:containers:- name: prometheusimage: prom/prometheus:latestargs:- "--config.file=/etc/prometheus/prometheus.yml"- "--storage.tsdb.path=/prometheus"- "--web.enable-lifecycle"- name: thanos-sidecarimage: thanosio/thanos:latestargs:- "sidecar"- "--prometheus.url=http://localhost:9090"- "--tsdb.path=/prometheus"

6. 使用 Operator 部署

Prometheus Operator 是 Kubernetes 上的一个扩展,简化了 Prometheus 的部署和管理。

特点:
  • 自动化部署和管理 Prometheus 实例。
  • 提供自定义资源定义(CRD)来配置 Prometheus。
  • 适用于 Kubernetes 环境。
适用场景:
  • Kubernetes 环境。
  • 需要自动化部署和管理的场景。
部署步骤:
  1. 安装 Prometheus Operator。
  2. 使用自定义资源定义(CRD)配置 Prometheus 实例。

bash

复制

# 安装 Prometheus Operator
kubectl apply -f https://raw.githubusercontent.com/prometheus-operator/prometheus-operator/main/bundle.yaml# 创建 Prometheus 实例
apiVersion: monitoring.coreos.com/v1
kind: Prometheus
metadata:name: prometheus
spec:serviceAccountName: prometheusserviceMonitorSelector:matchLabels:team: frontendresources:requests:memory: 400Mi

总结

不同的部署模式适用于不同的场景和需求。单节点部署适合小型环境,高可用部署适合生产环境,联邦部署和分片部署适合大规模分布式系统,而使用 Thanos 或 Cortex 的分布式部署适合需要长期存储和全局视图的场景。在 Kubernetes 环境中,使用 Prometheus Operator 可以简化部署和管理。

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

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

相关文章

FPGA中级项目4——DDS实现

FPGA中级项目4——DDS实现 DDS简介 DDS(直接数字频率合成器,Direct Digital Frequency Synthesis)是一种基于数字信号处理技术的频率合成方法,广泛应用于通信、雷达、仪器仪表等领域。在 FPGA中实现 DDS 具有灵活性高、集成度强、…

SAP的WPS导出找不到路径怎么办;上载报错怎么办

一.打开注册编辑器 二.输入以下地址 计算机\HKEY_CLASSES_ROOT\ExcelWorksheet\Protocol\StdFileEditing\Server 去除掉EXE后面的命令即可 二:WPS上载文件没反应怎么办 如何切换整合模式或多组件模式-WPS学堂 根据官方操作把整合模式改成多组件模式

STM32 DAC详解:从原理到实战输出正弦波

目录 一、DAC基础原理1.1 DAC的作用与特性1.2 DAC功能框图解析 二、DAC配置步骤2.1 硬件配置2.2 初始化结构体详解 三、DAC数据输出与波形生成3.1 数据格式与电压计算3.2 正弦波生成实战3.2.1 生成正弦波数组3.2.2 配置DMA传输3.2.3 定时器触发配置 四、常见问题与优化建议4.1 …

MVC_Publish-Subscriber 模式中的事件处理程序

MVC_Publish-Subscriber 模式中的事件处理程序 MVC 中的事件处理:发布者-订阅者模式 程序启动时,controlRecipes将被传入addHandlerRender; addHandlerRender会侦听事件(addEventListener),并使用controlRecipes作为回调&#xf…

网络华为HCIA+HCIP 以太网链路聚合与交换机堆叠、集群

网络可靠性 网络的可靠性指当设备或者链路出现单点或者多点故障时保证网络服务不间断的能力。网络的可靠性可以从单板、设备、链路多个层面实现。 单板可靠性 以S12700E-8为例,设备提供8个线路板槽位、4个交换网板槽位、2个主控板槽位、6个电源模块槽位、4个风扇…

施耐德PLC仿真软件Modbus tcp通讯测试

安装仿真软件:EcoStruxure™ Control Expert - PLC 仿真器 下载地址:https://www.schneider-electric.cn/zh/download/document/EIO0000001719/ 配置CPU: 切换至仿真模式,系统托盘中出现仿真器图标 新建变量test,地址…

LabVIEW棉花穴播器排种自动监测系统

一、项目背景与行业痛点 1. 农业需求驱动 我国棉花主产区,种植面积常年超250万公顷,传统人工播种存在两大核心问题: 效率瓶颈:人均日播种面积不足0.5公顷,难以匹配规模化种植需求; 精度缺陷:人…

2024浙江大学计算机考研上机真题

2024浙江大学计算机考研上机真题 2024浙江大学计算机考研复试上机真题 2024浙江大学计算机考研机试真题 2024浙江大学计算机考研复试机试真题 历年浙江大学计算机复试上机真题 历年浙江大学计算机复试机试真题 2024浙江大学计算机复试上机真题 2024浙江大学计算机复试机试真题 …

GPU视频编解码:Jetson VPI+multimedia_api视频编解码入门(一)

目录 一.Pipline与工具栈 二.硬件设备概况 三.GPU视频编解码框架 四.VPI编译使用实例 五. jetson_multimedia_api编译使用实例 一.Pipline与工具栈 二.硬件设备概况 三.GPU视频编解码框架 jetson设备目前不支持VPF框架,关于VPF的使用我在下节PC段使用X86进行安…

设计模式-对象创建

对象创建 前言1. Factory Method1.1 模式介绍1.2 模式代码1.2.1 问题代码1.2.2 重构代码 1.3 模式类图1.4 要点总结 2. Abstract Factory2.1 模式介绍2.2 模式代码2.2.1 问题代码2.2.2 重构代码 2.3 模式类图2.4 要点总结 3. Prototype3.1 模式介绍3.2 模式代码3.3 模式类图3.4…

【大模型基础_毛玉仁】2.6 非 Transformer 架构

更多内容:XiaoJ的知识星球 目录 2.6 非 Transformer 架构2.6.1 状态空间模型 SSM1)SSM(State Space Model)2)RWKV(Receptance Weighted Key Value)3)Mamba 2.6.2 训练时更新TTT(Test…

压测实战 | 微信小程序商城 “双 11” 的压测实践

背景 某全球知名珠宝品牌,始终以创新驱动零售变革。随着全渠道战略的深化,其小程序官方商城逐渐成为品牌私域流量的核心阵地,不仅承载了线上销售、会员运营等功能,同时还与其内部系统打通,如会员管理系统、人力资源系…

Webpack vs Rollup vs Parcel:构建工具深度对比

文章目录 1. 核心特性对比1.1 功能定位1.2 技术架构对比 2. 配置与使用2.1 Webpack 配置示例2.2 Rollup 配置示例2.3 Parcel 使用示例 3. 性能对比3.1 构建速度3.2 输出质量 4. 生态系统4.1 插件生态4.2 学习曲线 5. 适用场景分析5.1 Webpack 适用场景5.2 Rollup 适用场景5.3 P…

JUC大揭秘:从ConcurrentHashMap到线程池,玩转Java并发编程!

目录 JUC实现类 ConcurrentHashMap 回顾HashMap ConcurrentHashMap CopyOnWriteArrayList 回顾ArrayList CopyOnWriteArrayList: CopyOnWriteArraySet 辅助类 CountDownLatch 线程池 线程池 线程池优点 ThreadPoolExecutor 构造器各个参数含义: 线程…

【unity实战】用unity封装一个复杂全面且带不同射击模式的飞机大战射击系统

考虑到每个人基础可能不一样,且并不是所有人都有同时做2D、3D开发的需求,所以我把 【零基础入门unity游戏开发】 分为成了C#篇、unity通用篇、unity3D篇、unity2D篇。 【C#篇】:主要讲解C#的基础语法,包括变量、数据类型、运算符、流程控制、面向对象等,适合没有编程基础的…

【AWS入门】Amazon EC2简介

【AWS入门】Amazon EC2简介 A Brief Introduction to Amazon EC2 By JacksonML 1. 背景 众所周知,互联网时代的用户每天需要访问Web站点,以获取不同的信息和数据。而海量的Web站点,其内容均存放在服务器上,无论服务器有多远&am…

PyTorch系列教程:基于LSTM构建情感分析模型

情感分析是一种强大的自然语言处理(NLP)技术,用于确定文本背后的情绪基调。它常用于理解客户对产品或服务的意见和反馈。本文将介绍如何使用PyTorch和长短期记忆网络(LSTMs)创建一个情感分析管道,LSTMs在处…

Vue 渲染 LaTeX 公式 Markdown 库

🌟 前言 欢迎来到我的技术小宇宙!🌌 这里不仅是我记录技术点滴的后花园,也是我分享学习心得和项目经验的乐园。📚 无论你是技术小白还是资深大牛,这里总有一些内容能触动你的好奇心。🔍 &#x…

如何在WordPress中添加下载链接?

在WordPress网站上添加文件下载链接,不仅能提升用户体验,还能增加网站的互动性和实用价值。不管是提供免费的电子书、软件,还是其他类型的文件,下载链接都可以让用户快速获取所需的资源,增强他们对网站的好感。 本文将…

C/C++ 内存管理

1.C/C内存分布 sizeof和strlen有什么区别: 本质区别 特性sizeofstrlen类型运算符(编译时计算)库函数(运行时计算)作用对象变量、数据类型、表达式仅限以 \0 结尾的字符串(char* 或字符数组)功…