簡體   English   中英

KEDA 不根據 RabbitMQ 隊列長度擴展 Pod

[英]KEDA not scaling pods based on RabbitMQ queue length

我正在嘗試使用 KEDA 根據 RabbitMQ 消息隊列的當前長度自動擴展 Celery worker pod。 工作人員按預期運行,但是,它沒有在負載下擴展。

作為參考,我使用的是 KEDA v2.7.1。

來自 keda-operator pod 的日志:

1.6569289126033094e+09  ERROR   controller.scaledobject Reconciler error        {"reconciler group": "keda.sh", "reconciler kind": "ScaledObject", "name": "celery-worker-scaler", "namespace": "default", "error": "error establishing rabbitmq connection: dial tcp: lookup rabbitmq on 10.96.0.10:53: server misbehaving"}
sigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).processNextWorkItem
        /go/pkg/mod/sigs.k8s.io/controller-runtime@v0.11.2/pkg/internal/controller/controller.go:266
sigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).Start.func2.2
        /go/pkg/mod/sigs.k8s.io/controller-runtime@v0.11.2/pkg/internal/controller/controller.go:227

顯然連接到rabbitmq pod有一些問題

keda.yaml:

apiVersion: keda.sh/v1alpha1
kind: ScaledObject
metadata:
  name: celery-worker-scaler
  namespace: default
spec:
  scaleTargetRef:
    name: celery-worker
  pollingInterval: 3
  minReplicaCount: 1
  maxReplicaCount: 10
  triggers:
    - type: rabbitmq
      metadata:
        host: amqp://guest:guest@rabbitmq:5672
        protocol: amqp
        queueName: celery
        mode: QueueLength
        value: "5"

rabbitmq.yaml:

# deployment
apiVersion: apps/v1
kind: Deployment
metadata:
  name: rabbitmq
  labels:
    app: rabbitmq
spec:
  replicas: 1
  selector:
    matchLabels:
      app: rabbitmq
  template:
    metadata:
      labels:
        app: rabbitmq
    spec:
      containers:
      - name: rabbitmq
        image: rabbitmq:management
        env:
          - name: RABBITMQ_DEFAULT_USER
            valueFrom:
              secretKeyRef:
                name: secret
                key: rabbitmq-user
          - name: RABBITMQ_DEFAULT_PASS
            valueFrom:
              secretKeyRef:
                name: secret
                key: rabbitmq-password
        ports:
        - containerPort: 15672
          name: management
        - containerPort: 5672
          name: rabbitmq
---
# service
apiVersion: v1
kind: Service
metadata:
  name: rabbitmq
  labels:
    app: rabbitmq
spec:
  selector:
    app: rabbitmq
  ports:
  - port: 5672
    name: rabbitmq
    targetPort: rabbitmq
    protocol: TCP
  - port: 15672
    name: rabbitmq-mgmt
    targetPort: management

keda.yaml 文件應用在 keda 命名空間中(盡管我在頂部寫了 default)。 由於我的 rabbitmq pod 位於默認命名空間中,因此我必須將主機設置如下: amqp://guest:guest@rabbitmq.default:5672

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM