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. Nginx AWS ELB 域名解析后端502问题

    转载:http://liyangliang.me/posts/2016/04/nginx-aws-elb-name-resolution/

  2. Machine Learing 入门 —— 开门第0篇

    一.最近懒了 7月没怎么写博客,倒是一直在学Machine Learning的入门知识,在这里给大家推荐一个不错的自学网站:https://www.coursera.org/ ,Andrew Ng是联 ...

  3. ABAP和Java里关于DEFAULT(默认)机制的一些语言特性

    ABAP 740的新语法: 上图的代码相当于: DATA: ls_data LIKE LINE OF it_data. READ TABLE it_data INTO ls_data WITH KEY ...

  4. 防止HTML出现滚动条时页面的抖动

    <html> <style> * { padding: 0; margin: 0; } body { font: 40px fantasy; } .container { wi ...

  5. sql语句更新某字段内容中部分数据

    使用到的sql 语句的关键字就是replace, 如下图,把带有zhangjun 的值替换成 user 使用的sql语句就是 update 表名 set 字段名=replace(字段名,‘替换字符内容 ...

  6. 【Unity3D】【NGUI】UIRect的Anchor的使用

    NGUI版本号:3.6.5 以以下的图,解释下主要的Anchors的使用(能够通过官方的Anchor和Chat样例进行深入学习) Target不是一定要是Sprite.能够是随意的UIRect(UIS ...

  7. SPOJ 694 不同子串个数

    一个论文题,求一个字符串有多少个不同的子串. 每个字符串可以看做一个后缀的前缀,然后,就转换为求每一个后缀中,不同的子串有多少. 每一个后缀,根据长度,可以提供len - sa[i] 个子串,但是,画 ...

  8. hiho 第155周 任务分配

    最小路径覆盖会超时: 贪心思路: 按照开始时间排序,然后根据结束时间,维护一个以结束时间的单调递增的队列,每次与最快结束的任务进行比较即可: /* #include <cstdio> #i ...

  9. 动态规划(DP),压缩状态,插入字符构成回文字符串

    题目链接:http://poj.org/problem?id=1159 解题报告: 1.LCS的状态转移方程为 if(str[i-1]==str[j-1]) dp[i][j]=dp[i-1][j-1] ...

  10. nginx 图片,js,css等文件允许跨域

    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|mp4|ico)$ { #允许跨域请求 add_header Access-Control-Allow-Ori ...