虽然通过了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. 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 的安 ...

  2. Timeline扩展功能实践指南

    转载于http://forum.china.unity3d.com/forum.php?mod=viewthread&tid=32842,介绍了timeline的轨道扩展 Timeline功能 ...

  3. 【easy】438.Find All Anagrams in a String 找出字符串中所有的变位词

    Input: s: "abab" p: "ab" Output: [0, 1, 2] Explanation: The substring with start ...

  4. Oracle_CDC异步Autolog online redo部署示例

    一.CDC简介 Oracle CDC (Change Data Capture)变化数据捕获,是一种数据增量处理技术.CDC特性是在Oracle9i数据库中引入的.CDC能够帮助你识别从上次提取之后发 ...

  5. 24 类:组合 继承 super关键字 面向对象的三大性

    组合 组合:自定义类的对象作为另外一个类的属性 class Teacher: def __init__(self, name, age): self.name = name self.age = ag ...

  6. SQLAlchemy使用(三)搭配Flask框架使用

    前言 本章应该是SQLAlchemy使用系列的最后一篇了,本章简单讲一下如何搭配Flask使用.下一篇应该是写Flask_restful相关内容了 正文 我们简单使用前两章的model,两张表 # - ...

  7. python正则表达式--match search方法

    1.re.match函数 re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回None. (1)函数语法: re.match(pattern, st ...

  8. Unity中各种格式计时器

    问题背景: 在开发游戏过程中,很多地方需要倒计时,但是各种地方要的倒计时格式不同,倒计时都会写,在这里不详细介绍,写的目的就是为了记录一下,方便复用(为了在开发过程中不为了小问题浪费不必要脑细胞) 1 ...

  9. JS监听浏览器的返回、后退、上一页按钮的事件方法

    在实际的应用中,我们常常需要实现在移动app和浏览器中点击返回.后退.上一页等按钮实现自己的关闭页面.调整到指定页面或执行一些其它操作的需求,那在代码中怎样监听当点击微信.支付宝.百度糯米.百度钱包等 ...

  10. Nginx下完美解决WordPress的伪静态 (wordpress 迁移后 导致 页面404)

    直奔主题 如何设置WordPress在 Nginx下的伪静态 第一步:按照文章名为例,登陆后台按照箭头顺序修改固定连接,点击保存更改 第二步:登陆宝塔面板后台,按照文件路径 找到属于要配置域名的con ...