单节点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
相关推荐
我爱娃哈哈6 小时前
SpringBoot + SkyWalking + Prometheus:微服务全链路监控与性能压测闭环方案
spring boot·prometheus·skywalking
牛奶咖啡137 小时前
Prometheus+Grafana构建云原生分布式监控系统(四)
云原生·grafana·prometheus·redis_exporter·监控redis数据库·redis需要监控的重要指标·redis监控可视化
牛奶咖啡137 小时前
Prometheus+Grafana构建云原生分布式监控系统(五)
云原生·grafana·prometheus·监控nginx·两种监控nginx方法·nginx源码编译参数解析·编译nginx源码实操
AC赳赳老秦1 天前
Prometheus + DeepSeek:自动生成巡检脚本与告警规则配置实战
前端·javascript·爬虫·搜索引擎·prometheus·easyui·deepseek
A-刘晨阳1 天前
【Linux】Prometheus + Grafana的使用
linux·运维·grafana·prometheus·监控
牛奶咖啡131 天前
Prometheus+Grafana构建云原生分布式监控系统(三)
grafana·prometheus·云原生监控·监控linux主机状态·node_exporter安装·监控mysql数据库实践·mysql_exporter
Java程序员威哥1 天前
Java微服务可观测性实战:Prometheus+Grafana+SkyWalking全链路监控落地
java·开发语言·python·docker·微服务·grafana·prometheus
牛奶咖啡133 天前
Prometheus+Grafana构建云原生分布式监控系统(二)
prometheus·prometheus工作流程·prometheus适用场景·prometheus下载安装·prometheus指标解析·ntp时间同步操作·prometheus配置解析
这儿有个昵称4 天前
互联网大厂Java面试场景:从Spring框架到微服务架构的提问解析
java·spring boot·微服务·kafka·grafana·prometheus·数据库优化