在k8s上暴露EMQX(v4)的指标

1.开启prometheus 插件

部署的是 EMQX 4.4 开源版, 则需要通过 EmqxPlugin CRD 开启emqx_prometheus 插件:

bash 复制代码
cat << "EOF" | kubectl apply -f -
apiVersion: apps.emqx.io/v1beta4
kind: EmqxPlugin
metadata:
  name: emqx-prometheus
spec:
  pluginName: emqx_prometheus
  selector:
    apps.emqx.io/instance: emqx
    apps.emqx.io/managed-by: emqx-operator

获取AppID和AppSecret

bash 复制代码
curl -u {AppID}:{AppSecret} -X GET localhost:18083/api/v4/emqx_prometheus?type=prometheus

2.配置 EMQX 服务的 Kubernetes Service

确保 EMQX 的接口通过一个 Kubernetes Service 暴露。

yaml 复制代码
kind: Service
apiVersion: v1
metadata:
  name: emqx-prometheus
  labels:
    app: emqx
spec:
  ports:
    - name: prometheus
      protocol: TCP
      port: 18083
      targetPort: 18083
  type: ClusterIP
  selector:
    apps.emqx.io/instance: emqx
    apps.emqx.io/managed-by: emqx-operator

3.创建 ServiceMonitor

yaml 复制代码
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
  name: emqx-monitor
spec:
  endpoints:
    - basicAuth:
        password:
          key: password
          name: emqx-basic-auth
        username:
          key: username
          name: emqx-basic-auth
      params:
        type:
          - prometheus
      path: /api/v4/emqx_prometheus
      port: prometheus
      scheme: http
  namespaceSelector:
    matchNames:
      - mes-emqx
  selector:
    matchLabels:
      app: emqx

4.创建 BasicAuth Secret

bash 复制代码
kubectl create secret generic emqx-basic-auth \
  --from-literal=username={AppID} \
  --from-literal=password={AppSecret}

5.验证Promethues 是否已经能读取到emqx的metric

相关推荐
王佑辉19 分钟前
【kubernetes】资源管理方式
kubernetes
码农秃头老李29 分钟前
系列5:基于Centos-8.6 Kubernetes master节点允许运行pod节点
linux·kubernetes·centos
duration~34 分钟前
基于Docker容器DevOps应用方案
docker·容器·devops
m0_6754470843 分钟前
从SRE视角透视DevOps的构建精髓
分布式·zookeeper·云原生
海绵波波1071 小时前
ModelScope-Agent(3):docker启动
docker·容器·eureka
rock——you3 小时前
docker容器报错No log line matching the ‘‘ filter
运维·docker·容器
aherhuo4 小时前
kubervirt使用与运行策略
运维·docker·容器
麻辣翅尖4 小时前
【解决】k8s使用flannel网络插件的问题整理
kubernetes·k8s·报错
Dyhamic4 小时前
在 Windows11 上安装k8s的包管理工具Helm
云原生·容器·kubernetes
CloudWeGo4 小时前
ROG:高性能 Go 实现
开发语言·微服务·云原生·架构·golang·rust·开源