k8s入門系列之擴展組件(一)DNS安裝篇


DNS (domain name system),提供域名解析服務,解決了難於記憶的IP地址問題,以更人性可讀可記憶可標識的方式映射對應IP地址。

Cluster DNS擴展插件用於支持k8s集群系統中各服務之間發現與調用。

  

組件:
  •SkyDNS 提供DNS解析服務
  •Etcd 存儲DNS信息
  •Kube2sky 監聽kubernetes,當有Service創建時,生成相應的記錄到SkyDNS。

 

本文章的實驗環境與《k8s入門系列之集群安裝篇》介紹中一致。master(1) + node(4)
1.修改所有node的配置文件:/etc/kubernetes/kubelet
node1,node2,node3.node4:

[root@node1 ~]# tail -n 1 /etc/kubernetes/kubelet

KUBELET_ARGS="--cluster-dns=10.254.254.254 --cluster-domain=cluster.local"

2.所有node(node1,node2,node3,node4)重新啟動kubelet服務

[root@node1 ~]# systemctl restart kubelet.service

3.根據namespace分為不同的名稱空間,將系統服務統一放到一個單獨的空間:kube-system,由於默認空間只有default,我們首先要創建kube-system空間。

[root@master skydns]# cat kube-system.yml

apiVersion: v1
kind: Namespace
metadata:
  name: kube-system

4.在master服務器上編輯ReplicationController文件skydns-rc.yml

[root@master skydns]# cat skydns-rc.yml

apiVersion: v1
kind: ReplicationController
metadata:
  name: kube-dns-v11
  namespace: kube-system
  labels:
    k8s-app: kube-dns
    version: v11
    kubernetes.io/cluster-service: "true"
spec:
  replicas: 1
  selector:
    k8s-app: kube-dns
    version: v11
  template:
    metadata:
      labels:
        k8s-app: kube-dns
        version: v11
        kubernetes.io/cluster-service: "true"
    spec:
      containers:
      - name: etcd
        image: docker.gaoxiaobang.com/kubernetes/etcd-amd64:2.2.1  
        resources:
          limits:
            cpu: 100m
            memory: 500Mi
          requests:
            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: docker.gaoxiaobang.com/kubernetes/kube2sky:1.14
        args:
        # command = "/kube2sky"
        - --domain=cluster.local
        - --kube-master-url=http://192.168.30.20:8080
        resources:
          limits:
            cpu: 100m
            memory: 200Mi
          requests:
            cpu: 100m
            memory: 50Mi
      - name: skydns
        image: docker.gaoxiaobang.com/kubernetes/skydns:2015-10-13-8c72f8c
        resources:
          limits:
            cpu: 100m
            memory: 200Mi
          requests:
            cpu: 100m
            memory: 50Mi
        args:
        - -machines=http://127.0.0.1:4001
        - -addr=0.0.0.0:53
        - -ns-rotate=false
        - -domain=cluster.local.
        ports:
        - containerPort: 53
          name: dns
          protocol: UDP
        - containerPort: 53
          name: dns-tcp
          protocol: TCP
        livenessProbe:
          httpGet:
            path: /healthz
            port: 8080
            scheme: HTTP
          initialDelaySeconds: 60
          timeoutSeconds: 5
          successThreshold: 1
          failureThreshold: 5
        readinessProbe:
          httpGet:
            path: /readiness
            port: 8080
            scheme: HTTP
          initialDelaySeconds: 30
          timeoutSeconds: 5
      - name: healthz
        image: docker.gaoxiaobang.com/kubernetes/exechealthz:1.0
        resources:
          limits:
            cpu: 10m
            memory: 20Mi
          requests:
            cpu: 10m
            memory: 20Mi
        args:
        - -cmd=nslookup kubernetes.default.svc.cluster.local localhost >/dev/null
        - -port=8080
        ports:
        - containerPort: 8080
          protocol: TCP
      volumes:
      - name: etcd-storage
        emptyDir: {}
      dnsPolicy: Default

5.在master上創建skydns服務文件skydns-svc.yml
[root@master skydns]# cat skydns-svc.yml

apiVersion: v1
kind: Service
metadata:
  name: kube-dns
  namespace: kube-system
  labels:
    k8s-app: kube-dns
    kubernetes.io/cluster-service: "true"
    kubernetes.io/name: "KubeDNS"
spec:
  selector:
    k8s-app: kube-dns
  clusterIP:  10.254.254.254
  ports:
  - name: dns
    port: 53
    protocol: UDP
  - name: dns-tcp
    port: 53
    protocol: TCP

6.在集群中創建cluster-dns解析應用

•創建Namespace

[root@master skydns]# kubectl create -f kube-system.yml

•創建ReplicationController

[root@master skydns]# kubectl create -f skydns-rc.yml

•創建Service

[root@master skydns]# kubectl create -f skydns-svc.yml

7.查看skydns-rc.yml文件中定義pod的啟動狀態,如下則啟動成功。

[root@master skydns]# kubectl get pod --namespace=kube-system
NAME                         READY     STATUS    RESTARTS   AGE
kube-dns-v11-ey14j           4/4       Running   8          1d

8.查看skydns-svc.yml文件中定義的Service的信息。

[root@master skydns]# kubectl get svc -l k8s-app=kube-dns --namespace=kube-system
NAME       CLUSTER-IP       EXTERNAL-IP   PORT(S)         AGE
kube-dns   10.254.254.254   <none>        53/UDP,53/TCP   1d

9.測試DNS的效果。
•部署一個busybox的Pod
[root@master test]# cat busybox.yml

apiVersion: v1
kind: Pod
metadata:
  name: busybox
  namespace: default
spec:
  containers:
  - image: busybox
    command:
      - sleep
      - "3600"
    imagePullPolicy: IfNotPresent
    name: busybox
  restartPolicy: Always

•驗證kubernetes服務的地址解析,出現如下所示則證明DNS解析正常。

[root@master test]# kubectl exec busybox nslookup kubernetes
Server:    10.254.254.254
Address 1: 10.254.254.254

Name:      kubernetes
Address 1: 10.254.0.1

*提示:kubernetes服務是kubernetes集群安裝之后默認的一個服務。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM