zoukankan      html  css  js  c++  java
  • Kubernetes-DNS

    Kubernetes提供的虚拟DNS服务名为skydns,由四个组件组成:

    1. etcd:DNS存储
    2. kube2sky:将Kubernetes Master中的Service(服务)注册到etcd
    3. skyDNS:提供DNS域名解析服务
    4. healthz:提供对skydns服务的健康检查功能。

    Kubernetes DNS服务的总体架构:

    skydns-rc.yaml文件中需要修改几个参数:

    • kube2sky容器需要访问Kubernetes Master,需要配置Master所在物理主机的IP地址和端口号,--kube-master-url的值为http://192.168.1.191:8080。
    • kube2sky容器和skydns容器的启动参数--domain,设置Kubernetes集群中Service所属的域名,本例中为cluster.local,启动后,kube2sky会通过APIserver监控集群中全部Service的定义,生成相应的记录保存在etcd中。kube2sky为每个Service生成以下两条记录:
      •   <service_name>.<namespace_name>.<domain>
      •    <service_name>.<namespace_name>.svc.<domain> 
    • skydns的启动参数--addr=0.0.0.0:35 表示使用本机TCP和UDP的53端口提供服务。
    • cat skydns-rc.yaml

    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: 192.168.1.191:5000/etcd:latest
               resources:
                  limits:
                    cpu: 100m
                    memory: 50Mi
                 requests:
                    cpu: 100m
                    memory: 50Mi
               command:
               - etcd
               - -data-dir
               - /tmp/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: /tmp/data
            - name: kube2sky
              image: 192.168.1.191:5000/kube2sky:kubernetes
              resources:
                 limits:
                   cpu: 100m
                   memory: 50Mi
                requests:
                   cpu: 100m
                  memory: 50Mi
              livenessProbe:
                httpGet:
                   path: /healthz
                   port: 8080
                   scheme: HTTP
                initialDelaySeconds: 60
                timeoutSeconds: 5
                successThreshold: 1
                failureThreshold: 5
              readinessProbe:
                 httpGet:
                    path: /readiness
                    port: 8081
                    scheme: HTTP
                initialDelaySeconds: 30
                timeoutSeconds: 5
              args:
               - --kube-master-url=http://192.168.1.191:8080
               - --domain=cluster.local
            - name: skydns
              image: 192.168.1.191:5000/skydns:latest
              resources:
                  limits:
                    cpu: 100m
                    memory: 50Mi
                 requests:
                     cpu: 100m
                     memory: 50Mi
              command:
              - /skydns
              - -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
           - name: healthz
             image: 192.168.1.191:5000/exechealthz-amd64:latest
             resources:
                limits:
                  cpu: 10m
                  memory: 20Mi
                requests:
                   cpu: 10m
                   memory: 20Mi
            args:
            - -cmd=nslookup kubernetes.default.svc.cluster.local 127.0.0.1 > /dev/null
            - -port= 8080
           ports:
           - containerPort: 8080
             protocol: TCP
       volumes:
       - name: etcd-storage
         emptyDir: {}
         dnsPolicy: Default

  • 相关阅读:
    备份服务-Rsync
    mysql查询语句,int类型加引号居然也能查
    echo显示带颜色
    python读文件
    python发送邮件
    javadoc源码获取
    mac修改终端用户名
    [tomcat]-tomcat8启动时SessionIdGeneratorBase.createSecureRandom耗时
    shell运算符
    shell中$*和$@ 两个都区别
  • 原文地址:https://www.cnblogs.com/cf532088799/p/7818691.html
Copyright © 2011-2022 走看看