How does mutiple replicas of kube-dns without a clustered etcd work?

7/18/2019

I have a Kubernetes v1.4.0 cluster with a kube-dns replicationController, as shown below. I am trying to figure out a way to restart the kube-minion(node) on which kube-dns is without taking a downtime.

Increasing the replicas to 2 would schedule a new pod on a different node and I can restart the node, but sky-dns is backed by etcd and etcd is not clustered. Would this strategy work at all without a clustered etcd?

Appreciate your help.

apiVersion: v1
kind: ReplicationController
metadata:
  name: kube-dns-v8
  namespace: default
  labels:
    k8s-app: kube-dns
    version: v8
    kubernetes.io/cluster-service: "true"
spec:
  replicas: 1
  selector:
    k8s-app: kube-dns
    version: v8
  template:
    metadata:
      labels:
        k8s-app: kube-dns
        version: v8
        kubernetes.io/cluster-service: "true"
    spec:
      containers:
      # etcd already running on master
      - name: etcd
        image: gcr.io/google_containers/etcd:2.0.9
        resources:
          limits:
            cpu: 100m
            memory: 50Mi
        command:
        - /usr/local/bin/etcd
        - -data-dir
        - /var/etcd/data
        - -listen-client-urls
        - http://127.0.0.1:2379,http://127.0.0.1:4001
        - -advertise-client-urls
        - http://127.0.0.1:2379,http://127.0.0.1:4001
        - -initial-cluster-token
        - skydns-etcd
        volumeMounts:
        - name: etcd-storage
          mountPath: /var/etcd/data
      - name: kube2sky
        image: gcr.io/google_containers/kube2sky:1.11
        resources:
          limits:
            cpu: 100m
            memory: 50Mi
        args:
          - -domain=kube.local
          - -kube_master_url=http://{{ hostvars[inventory_hostname].ansible_default_ipv4.address }}:8080
          - -etcd-server=http://127.0.0.1:4001
      - name: skydns
        image: skynetservices/skydns:latest
        resources:
          limits:
            cpu: 100m
            memory: 50Mi
        args:
          - -machines=http://127.0.0.1:2379,http://127.0.0.1:4001
          - -addr=0.0.0.0:53
          - -domain=kube.local
          - -nameservers={{ ansible_dns.nameservers[0] }}:53
        ports:
        - containerPort: 53
          name: dns
          protocol: UDP
        - containerPort: 53
          name: dns-tcp
          protocol: TCP
        livenessProbe:
          httpGet:
            path: /healthz
            port: 8080
            scheme: HTTP
          initialDelaySeconds: 30
          timeoutSeconds: 5
      - name: healthz
        image: gcr.io/google_containers/exechealthz:1.0
        resources:
          limits:
            cpu: 10m
            memory: 20Mi
        args:
          - -cmd=nslookup kubernetes.default.svc.kube.local localhost >/dev/null
          - -port=8080
        ports:
          - containerPort: 8080
            protocol: TCP
      volumes:
      - name: etcd-storage
        emptyDir: {}
      dnsPolicy: Default  # Don't use cluster DNS.
apiVersion: v1
kind: Service
metadata:
  name: kube-dns
  namespace: default
  labels:
    k8s-app: kube-dns
    kubernetes.io/cluster-service: "true"
    kubernetes.io/name: "KubeDNS"
spec:
  selector:
    k8s-app: kube-dns
  clusterIP: {{ cluster_nameserver1 }}
  ports:
  - name: dns
    port: 53
    protocol: UDP
  - name: dns-tcp
    port: 53
    protocol: TCP
-- NaveenBabuE
dns
kubernetes
skydns

0 Answers