虽然通过了Service解决了Pod重建后IP动态变化(服务发现)、负载均衡问题,但使用Service还是要需要知道CLUSTER-IP,而通过NDS可以解决该问题;在Kubernetes集群中可通过DNS进行Service服务名与IP进行映射,从而需要知道Service名称就可以访问该服务,这里将通过kube-dns来实现该功能;

  在https://github.com/kubernetes/kubernetes/tree/master/cluster/addons/dns中下载

 kubedns-cm.yaml
kubedns-controller.yaml.sed
kubedns-sa.yaml
kubedns-svc.yaml.sed

  四个文件,其中.sed结尾的两个文件为模板文件需要重命名为:kubedns-controller.yaml、kubedns-svc.yaml,并对两个文件做以下修改:

  Kubedns-controller.yaml文件中所有\(DNS_DOMAIN修改为:**cluster.local**
  Kubedns-svc.yaml文件中所有\)DNS_SERVER_IP修改为:10.254.0.2

  注意$DNS_SERVER_IP的IP必须在kube-apiserver的配置项--service-cluster-ip-range=10.254.0.0/16范围内;

  Kube-dns的域名格式为:<serviceName>.<namespace>.svc.<cluster_domain>

依赖

  由于kube-dns依赖于k8s-dns-kube-dns-amd64、k8s-dns-dnsmasq-nanny-amd64、k8s-dns-sidecar-amd64三个镜像,而此镜像都是google官方镜像必须从google站点下载,此时可通过第三方镜像仓库代理下载再pull到本地然后通过docker tag打上官方的标签(或修改kubedns-controller.yaml、kubedns-svc.yaml文件中镜像的地址为第三方地址),关于第三方镜像仓库代理下载可以看这篇文件:代理下载

安装

  经过现在上诉的操作后接下来可以安装kube-dns,执行下面几行命令;

 Kubectl create -f kubedns-cm.yaml
Kubectl create -f kubedns-sa.yaml
Kubectl create -f kubedns-svc.yaml
Kubectl create -f kubedns-controller.yaml

  创建完成后再dashboard中已可以看到kube-dns相关服务是否正常:

  由于node节点需要使用dns进行服务解析,所以还需要修改kubelet服务配置项,在kubelet配置文件中添加上dns配置:--cluster-dns=10.254.0.2、--cluster-domain=cluster.local两项配置正式上面yaml文件模板中所添加的值;此时DNS服务已安装完成;

验证DNS

  通过pod验证DNS,下面通过pod启动一个busybox容器验证dns是否正常;

  pod的yaml文件内容如下:

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

执行下面指令创建pod:

 Kubectl create -f busybox.yaml

  执行kubectl exec busybox nslookup kubernetes命令,如显示如下图信息则说明dns已正常运行;

  该命令为在容器busybox中执行nsloolup kubernetes查询kubernetes的dns信息;

  还可以执行kubectl exec busybox -- nslookup kubernetes.default.svc.cluster.local

kubernetes.default.svc.cluster.local为在kubedns-controller.yaml文件中配置的信息;

文章首发地址:Solinx

http://www.solinx.co/archives/1061

Kubernetes1.7—DNS安装的更多相关文章

  1. Linux centOS本地DNS安装

    centOS本地DNS安装 在centOS里最常用的DNS服务工具应该是bind了.下面就以bind为例做一个DNS服务. 首先查看bind 是否已经安装 Rpm -qa | gerp bind 如果 ...

  2. DNS 安装配置

    DNS 安装配置 实验环境 一台主机:Linux Centos 6.5 32位 安装包: DNS服务:bind.i686 DNS测试工具:bind-utils DNS 服务安装 1.yum安装DNS服 ...

  3. 本地DNS安装

    在centOS里最常用的DNS服务工具应该是bind了.下面就以bind为例做一个DNS服务. 首先查看bind 是否已经安装 Rpm -qa | gerp bind 如果没有的话就用yum 安装一下 ...

  4. k8s入门系列之扩展组件(一)DNS安装篇

    DNS (domain name system),提供域名解析服务,解决了难于记忆的IP地址问题,以更人性可读可记忆可标识的方式映射对应IP地址. Cluster DNS扩展插件用于支持k8s集群系统 ...

  5. 部署和调优 3.3 dns安装配置-3

    只有一台DNS服务器是不保险的,现在给他配置个从服务器. 在另外一台虚拟机上安装配置DNS服务器.先查看虚拟机ip为:192.168.1.111 ifconfig 给从安装bind和dig命令 yum ...

  6. 部署和调优 3.1 dns安装配置-1

    安装配置DNS服务器 装一个bind,首先搜一下. yum list |grep bind bind.x86_64   我们安装这个 安装 yum install bind.x86_64 -y 看一下 ...

  7. kubernetes学习与实践篇(二) kubernetes1.5 的安装和集群环境部署

    kubernetes 1.5 的安装和集群环境部署 文章转载自:http://www.cnblogs.com/tynia/p/k8s-cluster.html 简介: Docker:是一个开源的应用容 ...

  8. DNS安装配置主从

    准备环境  关闭防火墙 挂载一下 更改配置文件 安装dns服务 更改配置文件  先复制保存一份

  9. kubernetes1.13.5安装部署

    Kubernetes 一.    Kubernetes介绍 各节点所需组件 Master:docker,kubeadm,kubelet, 组件 版本 备注 Kubelet 1.13.5 组件 Kube ...

随机推荐

  1. UOJ #450「集训队作业2018」复读机

    UOJ #450 题意 有$ k$台复读机,每时每刻有且只有一台复读机进行复读 求$ n$时刻后每台复读机的复读次数都是$ d$的倍数的方案数 $ 1\leq d \leq 3,k \leq 5·10 ...

  2. Tomcat关闭失败,SEVERE: Could not contact localhost:8005. Tomcat may not be running.

    SEVERE: Could not contact localhost:8005. Tomcat may not be running. Tomcat 启动后,关闭失败,显示以下 进入 java 的安 ...

  3. Recon ASRC Conference

    场景 ASRC漏洞挖掘 方法论 1.Brands https://www.crunchbase.com/ https://en.wikipedia.org Footers & about us ...

  4. NBIoT三种部署方式【转】

    转自:https://472880.kuaizhan.com/89/34/p441944286fccf2 本文作者:吴老司撩通信 本文来源:EETOP NB-IoT支持在频段内(In-Band).保护 ...

  5. 【转】JAVA错误:The public type *** must be defined in its own file***

    出现The public type xxx must be defined in its own file这个问题,是由于定义的JAVA类同文件名不一致.public类必须定义在它自己的文件中. 解决 ...

  6. Java编程思想(后)

    Java编程思想(后) 持有对象 如果一个程序只包含固定数量的且其生命期都是已知的对象,那么这是一个非常简单的程序. Java中的库基本类型: List, Set, Queue和Map --- 称为集 ...

  7. C# 文件下载工具类FileDownHelper

    using System; using System.IO; using System.Threading; using System.Web; namespace 落地页测试代码 { public ...

  8. 屏蔽eslint代码格式报错

    1.在文件中找到node_modules 2.node_modules文件夹下的eslint-config-standard 3.打开eslint-config-standard文件夹下的eslint ...

  9. Linux基础-远程管理

    shutdown  选项  时间    关机/重新启动 -r 重新启动 不指定选项和参数,1分钟后关闭电脑 重启必须加-r 示例:  shutdown   -r now    now表示现在 shut ...

  10. Dapper+SqlServerCe部署

    C:\Program Files\Microsoft SQL Server Compact Edition\v4.0 目录下面 选择下面这 7 个 SQL Server Compact DLL,并复制 ...