kubernetes/minikube
View on GitHubChanging a Service from type: LoadBalancer to type: ClusterIP doesn't remove status.loadBalancer.ingress[]
Open
#9,972 opened on Dec 15, 2020
help wantedkind/buglifecycle/frozenlong-term-supportpriority/backlog
Description
Steps to reproduce the issue:
- minikube start --memory 8192 --cpus 8 --disk-size 80g
- minikube tunnel
- Create a Service my-svc with
type: LoadBalancer - Observe
kubectl get service my-svc -o yamlshowsstatus.loadBalancer.ingress[0].ipwith the service's clusterIP - kubectl patch service my-svc --type=merge -p "spec: {type: ClusterIP}"
Actual:
status.loadBalancer.ingress[0].ip remains.
Expected:
status.loadBalancer.ingress should be removed.
This would help automated tests that need to work with both minikube and cloud k8s clusters like GKE, that test adding and removing external access on Service.
We took a look at LoadBalancerEmulator, and saw that it has a method cleanupService(). However, it is only called on Services with type: LoadBalancer, and the cleanup methods are only called during shutdown.
Ideally, it seems like PatchServices should reconcile all Services to add or remove status.loadBalancer.ingress as appropriate.