k8s部署针对外部服务器的prometheus服务

news/2025/2/24 20:26:30

在Kubernetes(K8s)集群中部署Prometheus以监控外部服务器,涉及到几个关键步骤:配置Prometheus以抓取远程目标、设置服务发现机制、以及确保网络可达性。下面是一个详细指南,指导您如何在Kubernetes中部署并配置Prometheus,以便有效地监控不在集群内的外部服务器

1. 准备工作

  • 确保Kubernetes集群已就绪:您应有一个正在运行的Kubernetes集群,并具备使用kubectl管理集群的能力。
  • 了解Prometheus配置:熟悉Prometheus的基本配置结构,特别是关于如何定义静态和动态服务发现的部分。

2. 部署Prometheus

首先,通过Helm或直接使用YAML文件部署Prometheus到Kubernetes集群。这里以Helm为例,因为它提供了一种更便捷的方式来安装和管理Prometheus及其相关组件。

# 添加Prometheus社区仓库
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts

# 更新仓库
helm repo update

# 部署Prometheus
helm install prometheus prometheus-community/prometheus

3. 配置Prometheus抓取外部目标

Prometheus支持通过静态配置文件直接列出抓取目标,或是利用服务发现机制动态发现目标。对于外部服务器,最直接的方式是修改Prometheus配置以包含这些外部目标。

修改Prometheus配置
  1. 获取Prometheus配置映射:首先,找出Prometheus Deployment或StatefulSet中配置映射的名称。

    kubectl get pod -l app.kubernetes.io/name=prometheus -o jsonpath='{.items[0].spec.containers[0].volumeMounts[0].name}'
    ​
    
  2. 编辑配置映射:使用 kubectl edit命令编辑配置映射,添加外部服务器的抓取配置。

    kubectl edit cm <configmap-name> -n <namespace>
    ​
    

    在 scrape_configs部分添加如下配置,替换 <external_server_ip>和 <port>为实际值:

    scrape_configs:
      - job_name: 'external-server'
        static_configs:
          - targets: ['<external_server_ip>:<port>']
        metrics_path: '/metrics' # 根据外部服务器的实际指标路径调整
        scheme: 'http' # 或https,取决于服务器配置
    ​
    
  3. 重启Prometheus Pod:保存配置变更后,重启Prometheus Pod以应用新的配置。

    kubectl rollout restart deployment/prometheus -n <namespace>
    ​
    

4. 确保网络可达性

为了让Prometheus能够成功抓取外部服务器的指标,需要确保Kubernetes集群与外部服务器之间的网络连接畅通。这可能涉及以下几种情况:

  • 防火墙规则:确保集群的网络策略和外部服务器的防火墙允许Prometheus服务器的IP地址访问指定端口。
  • NAT与路由:如果Kubernetes集群位于私有网络内,可能需要设置NAT规则或端口转发,以允许出站连接到外部服务器
  • TLS与认证:如果外部服务器使用HTTPS或需要身份验证,需在Prometheus配置中提供相应的证书和认证信息。

5. 验证配置

  • 检查Prometheus UI:访问Prometheus的Web界面,查看 Status -> Targets,确保新添加的外部服务器目标状态为 UP
  • 查看指标:在Prometheus UI中直接输入指标名查询,确认可以从外部服务器成功拉取数据。

http://www.niftyadmin.cn/n/5864791.html

相关文章

Python的子线程与主线程之间的通信并通知主线程更新UI

新建PLC类 PLC.py import json import time from threading import Threadfrom HslCommunication import SiemensS7Net, SiemensPLCS from PySide6.QtCore import QThread, Signal, QObjectfrom tdm.MsgType import MSG_TYPE_LOG, MSG_TYPE_MSGBOX# 自定义信号类&#xff0c;用…

ElasticSearch查询指南:从青铜到王者的骚操作

ElasticSearch查询指南&#xff1a;从青铜到王者的骚操作 本文来源于笔者的CSDN原创&#xff0c;由于掘金>已经去掉了转载功能&#xff0c;所以只好重新上传&#xff0c;以下图片依然保持最初发布的水印&#xff08;如CSDN水印&#xff09;。&#xff08;以后属于本人原创均…

vue-fastapi-admin 部署心得

vue-fastapi-admin 部署心得 这两天需要搭建一个后台管理系统&#xff0c;找来找去 vue-fastapi-admin 这个开源后台管理框架刚好和我的技术栈所契合。于是就浅浅的研究了一下。 主要是记录如何基于原项目提供的Dockerfile进行调整&#xff0c;那项目文件放在容器外部&#xf…

基于Spring Boot的公司资产网站设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

从零实现机器人自主避障

1. 编译工具安装 sudo apt update sudo apt install python3-catkin-pkg python3-rosdep python3-rosinstall-generator python3-wstool python3-rosinstall build-essential sudo rosdep init rosdep update2. 构建节点 mkdir -p ~/ros2_ws/src cd ~/ros2_ws ros2 pkg creat…

mysql之B+ 树索引 (InnoDB 存储引擎)机制

b树索引机制 B 树索引 (InnoDB 存储引擎)机制**引言&#xff1a;****1. 数据页结构与查找**2. 索引的引入**3. InnoDB 的 B 树索引****4. InnoDB B 树索引的注意事项****5. MyISAM 的索引方案 (选读&#xff0c;与 InnoDB 做对比)****6. MySQL 中创建和删除索引的语句** **B 树…

使用Socket编写超牛的http服务器和客户端(二)

客户端 动态扩展连接池、线程池优雅关闭、超时机制、健康检查等功能,并将代码模块化: 文件结构 HTTPClientProject/ ├── ConnectionPool.h ├── ConnectionPool.cpp ├── TaskQueue.h ├── ThreadPool.h ├── main.cpp 工程代码主要分为以下几个模块: Connectio…

go执行java -jar 完成DSA私钥解析并签名

起因&#xff0c;最近使用go对接百度联盟api需要使用到DSA私钥完成签名过程&#xff0c;在百度提供的代码示例里面没有go代码的支持&#xff0c;示例中仅有php、python2和3、java的代码&#xff0c;网上找了半天发现go中对DSA私钥解析支持不友好&#xff0c;然后决定使用在java…