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

Kubernetes-DNS的更多相关文章

  1. Kubernetes DNS 简介

    环境 $ sudo lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 16 ...

  2. Kubernetes DNS安装配置

    #镜像在谷歌上需要FQ###################################下载kubernetes#DNS#cd kubernetes/cluster/addons/dns#修改tr ...

  3. Kubernetes DNS 高阶指南(转发别人 解析很详细)

    转发地址:http://www.jintiankansha.me/t/Js1R84GGAl DNS 是 Kubernetes 的核心功能之一,Kubernetes 通过 kube-dns 或  Cor ...

  4. Kubernetes DNS服务配置案例

    首先创建DNS服务的RC配置文件skydns-rc.yaml apiVersion: v1 kind: ReplicationController metadata: name: kube-dns-v ...

  5. Kubernetes DNS的配置

    Kubernetes集群机制通过DNS进行服务名和ip的映射,如果没有配置dns,你可以通过下面命令查询到集群ip kubectl get svc --namespace=kube-system 得到 ...

  6. kubernetes dns 初步理解和使用 dnsmasq dns服务器跟host机器同步

    1.安装DNS后,pod就可以通过dns来解析service,从而实现通信 2.创建一个dns测试工具pod apiVersion: extensions/v1beta1 kind: Deployme ...

  7. kubernetes入门之skydns

    部署kubernetes dns服务 kubernetes可以为pod提供dns内部域名解析服务.其主要作用是为pod提供可以直接通过service的名字解析为对应service的ip的功能. 部署k ...

  8. 理解Kubernetes(1):手工搭建Kubernetes测试环境

    系列文章: 1. 手工搭建环境 1. 基础环境准备 准备 3个Ubuntu节点,操作系统版本为 16.04,并做好以下配置: 系统升级 设置 /etc/hosts 文件,保持一致 设置从 0 节点上无 ...

  9. kubernetes实现用户自定义扩缩容

    本文章主要参考walkthrough,aggregation和auth.涉及custom metric API的注册认证以及API server aggregation的相关知识.walkthroug ...

  10. 手动部署 kubernetes HA 集群

    前言 关于kubernetes HA集群部署的方式有很多种(这里的HA指的是master apiserver的高可用),比如通过keepalived vip漂移的方式.haproxy/nginx负载均 ...

随机推荐

  1. java maven项目 导入jar包注意

    1.将jar 包放到lib目录下 2.build path 3.点击maven主项目右键选择properties 4.选择myeclipse 下的第一个选项 5.点击add   选择archives ...

  2. Python模块 Socket

    一个简单的python socket编程 一.套接字 套接字是为特定网络协议(例如TCP/IP,ICMP/IP,UDP/IP等)套件对上的网络应用程序提供者提供当前可移植标准的对象.它们允许程序接受并 ...

  3. May 27th 2017 Week 21st Saturday

    I learned the value of hard work by working hard. 只有真的努力了,才会知道努力的价值. I remember in the movie, The Da ...

  4. Jmeter入门13 jmeter发送application/octet-stream二进制流数据

    http接口请求header里面 content-type: application/octet-stream  (二进制流数据),如何用jmeter发送请求? 1 添加http请求头 2 http请 ...

  5. google Cayley图谱数据库初试

    一.安装 mkdir cayley cd cayley mkdir src export GOPATH=$(pwd) go get github.com/google/cayley go build ...

  6. C++11之std::future和std::promise和std::std::packaged_task

    为什么C++11引入std::future和std::promise?C++11创建了线程以后,我们不能直接从thread.join()得到结果,必须定义一个变量,在线程执行时,对这个变量赋值,然后执 ...

  7. [转]这13个开源GIS软件,你了解几个?

    这些开源GIS软件,你了解几个?本文内容部分来源于一份罗列了关于GIS软件应用的文章,笔者将其编译整合. 地理信息系统(Geographic Information System,GIS)软件依赖于覆 ...

  8. Android学习笔记_17_Intent匹配规则(隐式意图)

    Android基本的设计理念是鼓励减少组件间的耦合,因此Android提供了Intent (意图) ,Intent提供了一种通用的消息系统,它允许在你的应用程序与其它的应用程序间传递Intent来执行 ...

  9. PL/SQL dev 工具连接远程服务器oracle注意点

    由于Oracle的庞大,有时候我们需要在只安装Oracle客户端如plsql.toad等的情况下去连接远程数据库,可是没有安装Oracle就没有一切的配置文件去支持. 最后终于发现一个很有效的方法,O ...

  10. Oracle中with关键字的使用

    open p_cr1 for with sqla as (select d.*, (select c.STATICMONTH from ly_zg_jzfbtstatic c where c.ID = ...