Prometheus 触发器
案例:基于 istio 的 QPS 指标伸缩
如果您使用 istio,业务 Pod 注入了 sidecar,会自动暴露一些七层的监控指标,最常见的是 istio_requests_total
,可以通过这个指标计算 QPS。
假设场景是:A 服务需要根据 B 服务处理的 QPS 进行伸缩。配置示例如下:
apiVersion: keda.sh/v1alpha1
kind: ScaledObject
metadata:
name: b-scaledobject
namespace: prod
spec:
scaleTargetRef:
apiVersion: apps/v1
kind: Deployment
name: a
pollingInterval: 15
minReplicaCount: 1
maxReplicaCount: 100
triggers:
- type: prometheus
metadata:
serverAddress: http://monitoring-kube-prometheus-prometheus.monitoring.svc.cluster.local:9090
query: |
sum(irate(istio_requests_total{reporter=~"destination",destination_workload_namespace=~"prod",destination_workload=~"b"}[1m]))
threshold: "100"
相比 prometheus-adapter 的优势
每次新增自定义指标,都要改动 prometheus-adapter
的配置,且改配置是集中式管理的,不支持通过 CRD 管理,配置维护较为繁琐。而 KEDA 方案只需要配置 ScaledObject
或 ScaledJob
这种 CRD,不同业务可以使用不同的 YAML 文件维护,利于配置维护。
prometheus-adapter
的配置语法晦涩难懂,不能直接写 PromQL
,需要学习 prometheus-adapter
的配置语法,增加了学习成本,而 KEDA 的 prometheus 配置则非常简单,指标可以直接使用 PromQL
查询语句,简单明了。
prometheus-adapter
仅支持根据 Prometheus 监控数据进行伸缩,而对于 KEDA 来说,Prometheus 只是众多触发器中的一种。
本页内容是否解决了您的问题?