11

How to flush CoreDNS Cache on kubernetes cluster?

I know it can be done by deleting the CoreDNS pods, but is there a proper way to to the cache flush ?

Fauzan
  • 654
  • 1
  • 7
  • 15

3 Answers3

16

@coollinuxoid's answer is not suitable for production environment, it will have temporary downtime because the commands will terminate all pods at the same time. Instead, you should use kubernetes deployment's rolling update mechanism by setting an environment variable to avoid the downtime with command:

kubectl -n kube-system set env deployment.apps/coredns FOO="BAR"
Tony Lee
  • 308
  • 3
  • 6
  • 1
    And `kubectl -n kube-system set env deployment.apps/coredns FOO-` to get rid of the env variable again... – Ralf Jan 12 '21 at 16:26
  • 11
    I think you can avoid setting an environment variable altogether: `kubectl rollout restart deployment coredns -n kube-system` – Nick May 21 '21 at 14:26
14

The best way, as you said, would be restarting coredns pods. This can be done easily, by scaling the coredns deployment to "0" and then, scale it back to the desired number. Like in the sample command below:

kubectl scale deployment.apps/coredns -n kube-system --replicas=0
kubectl scale deployment.apps/coredns -n kube-system --replicas=2

without timout:

kubectl rollout restart deployment coredns -n kube-system

Thanks @Nick for comment

clxoid
  • 2,577
  • 12
  • 21
-7

execute this in each rabbitmq pod to remove mnesia, then restart pods

rm -rf /bitnami/rabbitmq/mnesia