单节点K8s上安装Prometheus

目录

[使用 Helm 部署(推荐)](#使用 Helm 部署(推荐))

[1. 安装 Helm](#1. 安装 Helm)

[2. 添加 Prometheus Helm 仓库](#2. 添加 Prometheus Helm 仓库)

[3. 创建命名空间](#3. 创建命名空间)

4.安装

检查外部访问信息

遇到镜像问题


Helm 和Prometheus是什么?

Helm是 Kubernetes 的包管理工具,能极大简化应用的部署和管理。这是最快捷、最省心的方式。就像:

  • Ubuntu 的 APT
  • CentOS 的 YUM

Prometheus开源的监控系统,Kubernetes 集群的"眼睛和耳朵",用于:

  • 收集各种指标(CPU、内存、网络等)
  • 提供查询接口和告警机制
  • 成为监控 Kubernetes 集群的行业标准

具体安装步骤

1. 安装 Helm

如果尚未安装 Helm,可以通过官方脚本安装:

复制代码
curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3
chmod 700 get_helm.sh
./get_helm.sh

2. 添加 Prometheus Helm 仓库

Helm 通过"图表"来管理应用,首先需要添加包含 Prometheus 图表的仓库:

复制代码
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
helm repo update

3. 创建命名空间

为监控组件创建一个独立的命名空间,是个好习惯:

复制代码
kubectl create namespace monitoring

重要配置 :默认安装可能不使用持久化存储,这意味着重启后数据会丢失。对于生产环境,建议通过自定义 values.yaml文件启用持久化存储。

4.安装Prometheus

复制代码
helm install my-prometheus-stack prometheus-community/kube-prometheus-stack \
  --namespace monitoring \
  --create-namespace \
  --set grafana.service.type=NodePort \
  --set grafana.service.nodePort=30080 \
  --set grafana.adminPassword="admin" \
  --set prometheus.service.type=NodePort \
  --set prometheus.service.nodePort=30090 \
  --set alertmanager.service.type=NodePort \
  --set alertmanager.service.nodePort=30093

检查外部访问信息

安装成功后,查看如何从外部访问:

复制代码
# 获取服务器 IP
SERVER_IP=$(hostname -I | awk '{print $1}')

# 获取 NodePort 端口
kubectl get svc -n monitoring -o jsonpath='{range .items[*]}{.metadata.name}{": http://'$SERVER_IP':"}{.spec.ports[0].nodePort}{"\n"}{end}'

您现在可以先运行helm list -A和 kubectl get pods -n monitoring来了解当前的安装状态。

安装成功后,您可以通过以下地址访问:

  • Grafana : http://<服务器IP>:30080(用户名:admin,密码:admin

  • Prometheus : http://<服务器IP>:30090

  • Alertmanager : http://<服务器IP>:30093

遇到镜像问题

复制代码
#查看状态
kubectl get pods -n monitoring


编辑deployment文件:
kubectl edit deployment prometheus-kube-state-metrics -n monitoring

使用下面镜像加速网站,将源deployement文件中镜像换成加速后的地址重新删除pod,便会自动重新拉去。

https://console.ucloud.cn/

复制代码
编辑deployment文件:
kubectl edit deployment prometheus-kube-state-metrics -n monitoring
获取所有pod:
kubectl get pods -n monitoring
删除pod,会自动重新拉取:
kubectl delete pod -n monitoring prometheus-kube-state-metrics-5b667b7f89-97bhh
重启服务
kubectl rollout restart deployment prometheus-server -n monitoring

检查服务状态:
kubectl get svc -n monitoring
相关推荐
ElevenS_it1885 小时前
Zabbix+Prometheus+云监控告警统一接入实战:用Webhook+事件总线搭建多源告警归一化平台
kubernetes·zabbix·prometheus
成为你的宁宁16 小时前
【基于 Docker-compose 部署 Prometheus 监控系统实战教程 】
docker·容器·prometheus
成为你的宁宁16 小时前
【Prometheus+Grafana 监控平台二进制安装配置(图文实操详解)】
grafana·prometheus
蜀道山老天师19 小时前
实操|Prometheus Pushgateway 部署、推送与数据管理全流程
运维·服务器·云原生·prometheus
蜀道山老天师2 天前
Docker Compose实战案例:一键部署WordPress+Prometheus监控平台
运维·docker·容器·prometheus
川石课堂软件测试2 天前
接口测试常见面试题及答案
python·网络协议·mysql·华为·单元测试·prometheus·harmonyos
蜀道山老天师4 天前
从零搭建 Prometheus 监控 MySQL:含二进制安装、授权、exporter 配置全流程
运维·数据库·mysql·adb·云原生·prometheus
蜀道山老天师4 天前
Prometheus监控Hadoop集群(实操完整版,含避坑指南)
大数据·linux·运维·hadoop·云原生·prometheus
虎头金猫5 天前
Beszel 轻量服务器监控:多台服务器状态统一看,搭起来比 Prometheus 省事太多
linux·运维·服务器·分布式·kafka·开源·prometheus
是店小二呀5 天前
利用JiuwenSwarm创建活动规划团队,一句话落地利用JiuwenSwarm创建活动规划团队,一句话落地活动实战
人工智能·prometheus