CoreDNS介绍与使用

2023-05-16

介绍

在Kubernetes中DNS组件为整个集群提供DNS服务,从而实现服务之间的访问。Kubernetes的DNS服务在Kubernetes中经历了3个阶段:

  • 1.3版本之前skydns
  • 1.3-1.10版本kubedns
  • 1.11版本开始coredns

CoreDNS基于Go语言开发,通过串接一组实现DNS功能的插件的插件链路实现所有功能,并且允许用户自行开发和添加必要的插件。CoreDNS底层使用Caddy作为WebServer,可以支持UDP、TLS、gRPC等方式对外提供DNS服务。

CoreDNS部署

下载CoreDNS deployment文件

下载地址:https://github.com/coredns/deployment/tree/master/kubernetes
在这里插入图片描述

wget https://github.com/coredns/deployment/raw/master/kubernetes/coredns.yaml.sed
mv coredns.yaml.sed coredns.yml

修改deployment文件

修改cluster.local和安装集群时设置的集群域名后缀保持一致
forward 后面设置为 /etc/resolv.conf
在这里插入图片描述
副本数根据负载情况修改
在这里插入图片描述
pod资源限制建议配置大一些,不然在负载大的情况下查询时间会增加
在这里插入图片描述

service IP和kubelete 配置文件中clusterDNS的值保持一致
在这里插入图片描述

部署

kubectl apply -f coredns.yml

测试

进入一个Pod进行域名解析测试
在这里插入图片描述

coreDNS配置文件

coreDNS的配置配置定义在名为Corefile的文件中,Corefile保存在kube-system名称空间下名为coredns的configmap中,然后以存储卷的形式挂载至coredns Pod中。具体内容如下:

    .:53 {
        errors	#将错误日志发送至标准输出
        health {	#通过http://loaclhost:8080/health报告健康状态
          lameduck 5s
        }
        ready	#所有插件就绪后通过8181端口响应200 Ok报告就绪状态
        kubernetes cluster.local in-addr.arpa ip6.arpa {	#Kubernetes系统的本地区域及专用的解析配置
          pods insecure
          fallthrough in-addr.arpa ip6.arpa
        }
        prometheus :9153	#通过http://localhost:9153/metrics暴露指标数据
        forward . /etc/resolv.conf {	#非Kubernetes集群内部域名的转发逻辑
          max_concurrent 1000
        }
        cache 30	#启用解析缓存,缓存时长30s
        loop	#检测是否存在解析循环,如果有终止其过程
        reload	#Corefile内容改变时自动重载配置信息
        loadbalance	#轮询DNS域名解析,如果一个域名存在多个记录就轮询解析
    }

如果有些域名要转给特定的dns服务器解析,可以在Corefile中添加类似下面的配置指定dns服务器:
在这里插入图片描述
修改完成以后等待CoreDNS重新加载配置或者重建CoreDNS Pod即可。

coreDNS解析流程

在这里插入图片描述

  1. client Pod根据/etc/resolv.conf将解析请求转发给kube-dns service
  2. kube-dns service会将请求转发到后端的coreDNS Pod
  3. coredns Pod 根据Corefile的配置会连接到kubernetes service监视service IP的变动,维护DNS解析记录
  4. CoreDNS查询到service name对应的IP后返回给客户端
  5. 如果查询的是外部域名,coreDNS无法解析,就转发给指定的域名服务器,一般是节点上/etc/resolv.conf中的服务器解析
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

CoreDNS介绍与使用 的相关文章

随机推荐

  • LAS文件中的时间戳gps_time到底是什么时间?计算原理及时间转换

    LAS文件中规定的时间gps time LAS官方资料 xff1a The LAS file format contains a header block variable length records and point data LAS
  • 某产品流失用户调研定性访谈提纲摘要

    原创不易 麻烦点个关注 点个赞 谢谢各位 流失用户调研定性访谈提纲 用户名 注册的用户类型 手机号码 公司 我是xxxx的xx 为了更好的为您提供更优质的产品和服务 现需花费您十分钟左右的时间 与您做一次简单的沟通 请问您方便吗 一 基本信
  • Spring Security Oauth2 扩展grant_type

    Spring Security Oauth2 自定义grant type的实现 在使用Jhipster 搭建微服务框架时 xff0c 使用了jhipster 提供的uaa做用户认证授权 xff0c Jhipster uaa 是基于sprin
  • 移动端产品比较分析:APP、小程序、H5

    原文 移动端产品比较分析 xff1a APP 小程序 H5 01 运行环境 xff08 1 xff09 APP xff1a Android 和 iOS 手机操作系统 xff08 2 xff09 小程序 xff1a 微信 APP 内 xff0
  • 产品工作基本流程

    我的博客即将同步至腾讯云 43 社区 xff0c 邀请大家一同入驻 xff1a https cloud tencent com developer support plan invite code 61 2p5qjwxvujms4 产品工作
  • ODBC(Open Database Connectivity,开放数据库互连)

    ODBC Open Database Connectivity 开放数据库互连 是微软公司开放服务结构 WOSA Windows Open Services Architecture 中有关数据库的一个组成部分 它建立了一组规范 并提供了一
  • 数据结构考研408复习必看

    原创不易 麻烦点个关注 点个赞 谢谢各位 数据结构要点 第一章 概 论 数据就是指能够被计算机识别 存储和加工处理的信息的载体 数据元素是数据的基本单位 可以由若干个数据项组成 数据项是具有独立含义的最小标识单位 数据结构的定义 逻辑结构
  • 思科网络工程师必学

    网络工程师学习笔记 第一章 计算机基础知识 一 硬件知识 1 计算机系统的组成包括硬件系统和软件系统 硬件系统分为三种典型结构 1 单总线结构 2 双总线结构 3 采用通道的大型系统结构 中央处理器 CPU 包含运算器和控制器 2 指令系统
  • 什么是数字技术?

    数字技术 xff08 Digital Technology xff09 xff0c 是一项与电子计算机相伴相生的科学技术 xff0c 它是指借助一定的设备将各种信息 xff0c 包括 xff1a 图 文 声 像等 xff0c 转化为电子计算
  • 启示录:新加坡纬壹科技城成功建设经验

    数字TOD xff1a 在各省市新一年的重点工作中 xff0c 产业园区都被放在非常显赫的位置加以强调 xff0c 有的被冠以 高质量发展主战场 的地位 xff0c 有的则异常鲜明地提出 园区兴则产业兴 xff0c 园区强则经济强 的口号
  • 区块链技术赋能数字经济建设

    区块链技术是一项利用密码学算法 以去中心化方式集体维护一个可靠分布式数据库的新兴技术 它具有分布式 不可篡改 可追溯等特征 xff0c 能够弥补传统信用体系不足 防止信息篡改和伪造 节省全社会信用成本 xff0c 对金融 电子商务 智慧医疗
  • 启示录:日本涉谷未来之光TOD成功建设经验

    启示录 xff1a 日本涉谷未来之光TOD成功建设经验 数字TOD 在城市土地供应日益紧张 城市人口膨胀 公共交通快速发展的今天 xff0c 涩谷之光以复合业态功能叠加和选择重点业态精心打造 xff0c 并最大限度对接公共交通资源的开发策略
  • 夜间经济:激发新⼀轮消费潜力升级的新引擎

    数字TOD 夜间经济是现代城市业态之一 xff0c 指从当日下午6点到次日早上6点所包含的经济文化活动 xff0c 其业态囊括晚间购物 餐饮 旅游 娱乐 学习 影视 休闲等 夜间经济是现代城市经济的重要组成部分 xff0c 是促消费 稳就业
  • os模块和序列化

    os模块 和操作系统交互的模块 import os os makedirs dir1 dir2 创建多个文件夹 os mkdir dir3 创建一个文件夹 os removedirs 39 dir3 dir4 删除多个空文件夹 os rmd
  • 启示录:日本东京都二子玉川站TOD成功建设经验

    数字TOD 在成都两会期间印发的 关于实施幸福美好生活十大工程的报告 指出 xff0c 实施幸福美好生活十大工程 xff0c 将以满足人民群众日益增长的美好生活需要为根本目的 xff0c 从市民和企业反映最强烈 最迫切的领域着手 特别提出
  • 启示录:TOD分类及用地功能结构组成

    数字TOD 彼得 卡尔索普在 The Next American Metropolis 一书中描述了两类TOD 一类是城市TOD xff08 Urban TODs xff09 xff0c 位于区域性的干道的轻轨 重轨或快速的公交汽车的站点
  • 启示录:了解TOD模式的正确打开方式(一)

    数字TOD 提起TOD xff0c 到目前很多人可能还很懵懂 科普TOD xff0c 是笔者不可推卸的责任 所以一起回忆下电影 lt 流浪地球 gt 电影魔性台词先上 xff1a 34 北京第三区交通委提醒您 xff1a 道路千万条 xff
  • 启示录:了解TOD模式的正确打开方式(二)

    数字TOD 在中国的城市化进程中 xff0c 城市病 也在加速蔓延 xff0c 交通问题的加重以及土地资源的日益紧缺 xff0c 让生活在其中的人们饱受困扰 xff0c 这同时也引发了人们对城市发展模式的反思 为了实现城市的可持续化发展 x
  • 问题解决方案1-------------catkin_make编译时候的各种问题汇总

    文件移植和编译出现的问题汇总 我真实服了 xff0c 我几乎每一步都能遇到问题 xff0c 这是我catkin make时候遇到的新问题 xff1a 百度总结了一下 xff0c 文末附上链接 xff1a 1 Could not find a
  • CoreDNS介绍与使用

    介绍 在Kubernetes中DNS组件为整个集群提供DNS服务 xff0c 从而实现服务之间的访问 Kubernetes的DNS服务在Kubernetes中经历了3个阶段 xff1a 1 3版本之前skydns1 3 1 10版本kube