Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

HPA is not created for deployments with long names (over 53 characters) #704

Closed
aslom opened this issue Mar 27, 2020 · 5 comments
Closed
Assignees
Labels
bug Something isn't working good first issue Good for newcomers help wanted Looking for support from community

Comments

@aslom
Copy link

aslom commented Mar 27, 2020

Expected Behavior

Scaling works for deployments with long names.

Actual Behavior

Scaled object name must be very short if deployment name is long (for example when using UUID) as "keda-hpa-" prefix (10 character) is added to deployment name and may exceed 63 characters such as keda-hpa-kafkasource-knedk1-c28092d0-eb07-4d8d-970c-b21cd3cfe9e8.

HPA is not created:

{"level":"error","ts":1585323384.2876647,"logger":"controller_scaledobject","msg":"Failed to create new HPA in cluster","Request.Namespace":"default","Request.Name":"knative-demo-kafka-keda-src1","HPA.Namespace":"default","HPA.Name":"keda-hpa-kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6","error":"HorizontalPodAutoscaler.autoscaling \"keda-hpa-kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6\" is invalid: metadata.labels: Invalid value: \"keda-hpa-kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6\": must be no more than 63 characters","stacktrace":"github.com/go-logr/zapr.(*zapLogger).Error\n\t/go/pkg/mod/github.com/go-logr/zapr@v0.1.1/zapr.go:128\ngit.luolix.top/kedacore/keda/pkg/controller/scaledobject.(*ReconcileScaledObject).reconcileDeploymentType\n\tkeda/pkg/controller/scaledobject/scaledobject_controller.go:240\ngit.luolix.top/kedacore/keda/pkg/controller/scaledobject.(*ReconcileScaledObject).Reconcile\n\tkeda/pkg/controller/scaledobject/scaledobject_controller.go:155\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).reconcileHandler\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.2.2/pkg/internal/controller/controller.go:216\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).processNextWorkItem\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.2.2/pkg/internal/controller/controller.go:192\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).worker\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.2.2/pkg/internal/controller/controller.go:171\nk8s.io/apimachinery/pkg/util/wait.JitterUntil.func1\n\t/go/pkg/mod/k8s.io/apimachinery@v0.0.0-20190404173353-6a84e37a896d/pkg/util/wait/wait.go:152\nk8s.io/apimachinery/pkg/util/wait.JitterUntil\n\t/go/pkg/mod/k8s.io/apimachinery@v0.0.0-20190404173353-6a84e37a896d/pkg/util/wait/wait.go:153\nk8s.io/apimachinery/pkg/util/wait.Until\n\t/go/pkg/mod/k8s.io/apimachinery@v0.0.0-20190404173353-6a84e37a896d/pkg/util/wait/wait.go:88"}
{"level":"error","ts":1585323384.2878582,"logger":"controller-runtime.controller","msg":"Reconciler error","controller":"scaledobject-controller","request":"default/knative-demo-kafka-keda-src1","error":"HorizontalPodAutoscaler.autoscaling \"keda-hpa-kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6\" is invalid: metadata.labels: Invalid value: \"keda-hpa-kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6\": must be no more than 63 characters","stacktrace":"github.com/go-logr/zapr.(*zapLogger).Error\n\t/go/pkg/mod/github.com/go-logr/zapr@v0.1.1/zapr.go:128\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).reconcileHandler\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.2.2/pkg/internal/controller/controller.go:218\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).processNextWorkItem\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.2.2/pkg/internal/controller/controller.go:192\nsigs.k8s.io/controller-runtime/pkg/internal/controller.(*Controller).worker\n\t/go/pkg/mod/sigs.k8s.io/controller-runtime@v0.2.2/pkg/internal/controller/controller.go:171\nk8s.io/apimachinery/pkg/util/wait.JitterUntil.func1\n\t/go/pkg/mod/k8s.io/apimachinery@v0.0.0-20190404173353-6a84e37a896d/pkg/util/wait/wait.go:152\nk8s.io/apimachinery/pkg/util/wait.JitterUntil\n\t/go/pkg/mod/k8s.io/apimachinery@v0.0.0-20190404173353-6a84e37a896d/pkg/util/wait/wait.go:153\nk8s.io/apimachinery/pkg/util/wait.Until\n\t/go/pkg/mod/k8s.io/apimachinery@v0.0.0-20190404173353-6a84e37a896d/pkg/util/wait/wait.go:88"}

and scaled object that use deployment with long name

⇒  kubectl get scaledobjects.keda.k8s.io knative-demo-kafka-keda-src1
NAME                           DEPLOYMENT                                                        TRIGGERS   AGE
knative-demo-kafka-keda-src1   kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6   kafka      2m12s
aslom@m:~/Documents/awsm/go/src/github.com/kedacore/keda|bd8381e
⇒  kubectl get scaledobjects.keda.k8s.io knative-demo-kafka-keda-src1 -o yaml
apiVersion: keda.k8s.io/v1alpha1
kind: ScaledObject
metadata:
  creationTimestamp: "2020-03-27T15:36:20Z"
  finalizers:
  - finalizer.keda.k8s.io
  generation: 1
  labels:
    deploymentName: kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6
  name: knative-demo-kafka-keda-src1
  namespace: default
  ownerReferences:
  - apiVersion: sources.eventing.knative.dev/v1alpha1
    blockOwnerDeletion: true
    controller: true
    kind: KafkaSource
    name: knative-demo-kafka-keda-src1
    uid: 354d2e72-baf2-44f3-95d2-2f38414507d6
  resourceVersion: "675465"
  selfLink: /apis/keda.k8s.io/v1alpha1/namespaces/default/scaledobjects/knative-demo-kafka-keda-src1
  uid: 5636a541-3cf3-4bb6-af75-6c456836d0fd
spec:
  cooldownPeriod: 15
  maxReplicaCount: 10
  minReplicaCount: 0
  pollingInterval: 2
  scaleTargetRef:
    deploymentName: kafkasource-knative-demo-k-354d2e72-baf2-44f3-95d2-2f38414507d6
  triggers:
  - metadata:
      brokerList: my-cluster-kafka-bootstrap.kafka:9092
      consumerGroup: knative-demo-kafka-keda-src1
      topic: knative-demo-topic
    type: kafka
status:
  externalMetricNames:
  - lagThreshold

Steps to Reproduce the Problem

  1. git checkout v1.3.0
  2. Deploye scaled object (see above) kubectl apply -f ../knative-demo-kafka-keda-src1d.yaml
  3. Verify scaled object is created but HAP is not created - see logs from keda controllers kubectl logs -f -n keda keda-operator-...

Specifications

  • **KEDA Version: 1.3
  • Platform & Version:
  • Kubernetes Version:
kubectl version
Client Version: version.Info{Major:"1", Minor:"17", GitVersion:"v1.17.3", GitCommit:"06ad960bfd03b39c8310aaf92d1e7c12ce618213", GitTreeState:"clean", BuildDate:"2020-02-13T18:08:14Z", GoVersion:"go1.13.8", Compiler:"gc", Platform:"darwin/amd64"}
Server Version: version.Info{Major:"1", Minor:"17", GitVersion:"v1.17.4+IKS", GitCommit:"06b4447d3f958e995e61af88b750537b264d0fd7", GitTreeState:"clean", BuildDate:"2020-03-13T12:50:19Z", GoVersion:"go1.13.8", Compiler:"gc", Platform:"linux/amd64"}
  • **Scaler(s): Kafka
@aslom aslom added the bug Something isn't working label Mar 27, 2020
@zroubalik
Copy link
Member

The k8s resource's name limit is 253, label has limit 63 chars.

Seems like the bug was introduced by this #596, where we put HPA resource name into the label named app.kubernetes.io/name.

https://kubernetes.io/docs/concepts/overview/working-with-objects/common-labels/#labels describes this label as The name of the application it doesn't necessary be a unique name, as this is served by another label (app.kubernetes.io/instance). I think we can put there a value like keda-hpa or something like that.

Thanks @aslom, good catch!

@aslom
Copy link
Author

aslom commented Mar 27, 2020

@zroubalik great if the limit can be increased - right now with UUID used in naming Knative Kafka source deployment it allows up to 4 characters to name Kafka source or limit is exceeded :( More details in README in https://github.com/knative/eventing-contrib/pull/886/files

@zroubalik
Copy link
Member

Yeah, we definitely need to fix this, it will be quite an easy one.

@zroubalik zroubalik added good first issue Good for newcomers help wanted Looking for support from community labels Mar 27, 2020
@zroubalik zroubalik self-assigned this Mar 30, 2020
@zroubalik
Copy link
Member

Fixed

@bmalka
Copy link

bmalka commented Apr 17, 2022

I would like to reopen this issue as we have to same problem in 2.6.1 version:
1.650181258876292e+09 ERROR controller.scaledobject Failed to update ScaledObject with scaledObjectName label {"reconciler group": "keda.sh", "reconciler kind": "ScaledObject", "name": "kafka-scaledobject-xxxxxxxxxx-xxxxxxxxxx-xxxxxxxxx-xxx-xxxxxx-xxxxxxxxx", "namespace": "production", "error": "ScaledObject.keda.sh "kafka-scaledobject-xxxxxxxxxx-xxxxxxxxxx-xxxxxxxxx-xxx-xxxxxx-xxxxxxxxx" is invalid: metadata.labels: Invalid value: "kafka-scaledobject-xxxxxxxxxx-xxxxxxxxxx-xxxxxxxxx-xxx-xxxxxx-xxxxxxxxx": must be no more than 63 characters"}

SpiritZhou pushed a commit to SpiritZhou/keda that referenced this issue Jul 18, 2023
Signed-off-by: Vighnesh Shenoy <vshenoy@microsoft.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working good first issue Good for newcomers help wanted Looking for support from community
Projects
None yet
Development

No branches or pull requests

3 participants