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. ORACLE_ALIAS

    Oracle / PLSQL: ALIASES website:https://www.techonthenet.com/oracle/alias.php This Oracle tutorial e ...

  2. 3.Zabbix 3.0 部署

    请查看我的有道云笔记: http://note.youdao.com/noteshare?id=0139b8d2833129740be82e36a94e4fca&sub=5931260FCC8 ...

  3. Oracle调优-常用表KEEP到内存中

    数据迁移后性能受到影响,需要将老数据库中keep到内存中的表在新库中keep到内存中,使用如下方法. 新库设置db_keep_cache_size为适当值,这个值的大小不能小于需要keep的表的大小. ...

  4. 关于simotion建立同步/解除同步的问题

    关于simotion建立同步/解除同步的问题. 问题: [enable gearing][disable gearing][enable camming][disable camming]都是一个过程 ...

  5. python入门13 集合set

    set集合与数学中的集合同一个概念,是无序不重复元素组成的. #coding:utf-8 #/usr/bin/python """ 2018-11-10 dinghanh ...

  6. python入门11 元组tuple

    tuple元组是一种不可变数据类型,也是一种序列,因此可用序列的各类方法,比如切片和索引 #coding:utf-8 #/usr/bin/python """ 2018- ...

  7. BZOJ4066:简单题(K-D Tree)

    Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作:   命令 参数限制 内容 1 x y A 1<=x,y<=N,A是正整数 ...

  8. CSP

    CSP(Content-Security-Policy): 内容安全策略   作用: .限制资源获取 .报告资源获取越权   限制方式: .default-src限制全局 跟链接请求有关的东西,限制他 ...

  9. 作为PHP开发者请务必了解Composer

    Composer是一个非常流行的PHP包依赖管理工具,已经取代PEAR包管理器,对于PHP开发者来说掌握Composer是必须的. 对于使用者来说Composer非常的简单,通过简单的一条命令将需要的 ...

  10. redis的数据结构与命令

    以下部分文档,摘自51cto讲师:汤小洋 redis提供五种数据类型:string,hash,list,set及zset(sorted set). Redis数据就是以key­ value形式来存储的 ...