云原生化 - 监控(简约版)

要在程序中暴露指标,并符合 Prometheus 和 Kubernetes 的规范,可以按照以下步骤进行:

1. 选择合适的库

根据你的编程语言选择适合的 Prometheus 客户端库。例如:

  • Go : github.com/prometheus/client_golang
  • Java : io.prometheus:simpleclient
  • Python : prometheus_client
  • Node.js : prom-client

2. 定义和创建指标

在代码中定义需要监控的指标。常用的指标类型包括:

  • Counter: 计数器,只增不减。
  • Gauge: 测量某个值,可以增减。
  • Histogram: 用于记录分布的样本。
  • Summary: 用于计算和记录一组值的摘要统计信息。

示例(以 Go 为例):

go 复制代码
package main

import (
    "net/http"
    "github.com/prometheus/client_golang/prometheus"
    "github.com/prometheus/client_golang/prometheus/promhttp"
)

var (
    requestCount = prometheus.NewCounterVec(
        prometheus.CounterOpts{
            Name: "http_requests_total",
            Help: "Total number of HTTP requests",
        },
        []string{"method", "endpoint"},
    )
)

func init() {
    prometheus.MustRegister(requestCount)
}

func handler(w http.ResponseWriter, r *http.Request) {
    requestCount.WithLabelValues(r.Method, r.URL.Path).Inc()
    w.Write([]byte("Hello, World!"))
}

func main() {
    http.HandleFunc("/", handler)
    // 指定 /metric 路径专门用于指标的暴露
    http.Handle("/metrics", promhttp.Handler())
    http.ListenAndServe(":8080", nil)
}

3. 暴露指标

在你的应用程序中,通常会通过一个 HTTP 端点(如 /metrics)来暴露指标。确保这个端点可以被 Prometheus 访问。

4. 在 Kubernetes 中部署应用

创建一个 Kubernetes 部署文件,确保你的应用程序能够正确启动并暴露 /metrics 端点。

示例部署 YAML 文件:

yaml 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-app
spec:
  replicas: 1
  selector:
    matchLabels:
      app: my-app
  template:
    metadata:
      labels:
        app: my-app
    spec:
      containers:
      - name: my-app
        image: my-app-image:latest
        ports:
        - containerPort: 8080

5. 配置 Prometheus

在 Kubernetes 中配置 Prometheus,使其能够发现并抓取你的指标。你可以使用 ConfigMap 来配置 Prometheus。

一般部署 Prometheus 为 Kubernetes 运维人员的工作,开发人员不需要关注。但开发人员需要学习并配置指标,在 Kubernetes 中通常通过 ServiceMonitor 配置来实现。

示例 Prometheus 配置:

yaml 复制代码
scrape_configs:
  - job_name: 'my-app'
    kubernetes_sd_configs:
      - role: pod
    relabel_configs:
      - source_labels: [__meta_kubernetes_pod_label_app]
        action: keep
        regex: my-app
      - action: labelmap
        regex: __meta_kubernetes_pod_label_(.+)

示例 ServiceMonitor 配置:

yaml 复制代码
apiVersion: v1
kind: Service
metadata:
  name: my-app
  labels:
    app: my-app
spec:
  ports:
    - port: 8080
      targetPort: 8080
  selector:
    app: my-app
---
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
  name: my-app-monitor
  labels:
    app: my-app
spec:
  selector:
    matchLabels:
      app: my-app
  namespaceSelector:
    matchNames:
      - default
  endpoints:
    - port: http  # 假设你的服务配置中端口名称为 "http"
      path: /metrics
      interval: 30s

6. 部署和监控

一旦你完成了上述步骤,部署应用和 Prometheus。你可以通过 Prometheus 的 UI 来查看和查询你的指标。

7. 调整和优化

根据收集到的指标数据,监控应用的性能,并根据需要进行调整和优化。

总结

遵循这些步骤,你就可以在程序中暴露指标并符合 Prometheus 和 Kubernetes 的规范。

相关推荐
虚无境4 小时前
如何编写一个SpringBoot项目告警推送的Starter
java·prometheus·webhook
阿里云云原生19 小时前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
java_cj1 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
杨浦老苏1 天前
轻量级Docker仪表板Servedash
运维·docker·监控·群晖·仪表板
睡不醒男孩0308231 天前
云原生运维实战:高并发架构下的云原生可观测性、韧性降级与自动化干预体系
数据库·kubernetes·高并发·prometheus·devops·sre·缓存调优
互联网推荐官1 天前
上海软件定制开发公司推荐:从PaaS工程化路径看D-coding的技术取舍
云原生·云计算·paas·软件开发·开发经验·上海
sbjdhjd1 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
java_cj2 天前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
步步为营DotNet2 天前
基于.NET Aspire 实现云原生应用的高效监控与可观测性
云原生·.net·wpf
牛奶咖啡132 天前
KVM虚拟化与企业应用实践——给远端主机创建虚拟机
云原生·qemu·kvm·给远端主机创建虚拟机·创建uefi模式的虚拟机·安装openeulersp2·vnc与虚拟机环境搭建