使用 CoreDNS 进行服务发现
此页面介绍了 CoreDNS 升级过程以及如何安装 CoreDNS 而不是 kube-dns。
准备开始
你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 Minikube 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:
您的 Kubernetes 服务器版本必须不低于版本 v1.9. 要获知版本信息,请输入 kubectl version
.
关于 CoreDNS
CoreDNS 是一个灵活可扩展的 DNS 服务器,可以作为 Kubernetes 集群 DNS。与 Kubernetes 一样,CoreDNS 项目由 CNCF云原生计算基金会 持有。
通过在现有的集群中替换 kube-dns,可以在集群中使用 CoreDNS 代替 kube-dns 部署,或者使用 kubeadm 等工具来为您部署和升级集群。
安装 CoreDNS
有关手动部署或替换 kube-dns,请参阅 CoreDNS GitHub 工程。
迁移到 CoreDNS
使用 kubeadm 升级现有集群
在 Kubernetes 1.10 及更高版本中,当您使用 kubeadm
升级使用 kube-dns
的集群时,您还可以迁移到 CoreDNS。 在本例中 kubeadm
将生成 CoreDNS 配置(”Corefile”)基于 kube-dns
ConfigMap,保存联邦、存根域和上游名称服务器的配置。
如果您正在从 kube-dns 迁移到 CoreDNS,请确保在升级期间将 CoreDNS
特性门设置为 true
。例如,v1.11.0
升级应该是这样的:
kubeadm upgrade apply v1.11.0 --feature-gates=CoreDNS=true
在 Kubernetes 版本 1.13 和更高版本中,CoreDNS
特性门已经删除,CoreDNS 在默认情况下使用。 如果您想升级集群以使用 kube-dns,请遵循 此处 。
在 1.11 之前的版本中,核心文件将被升级过程中创建的文件覆盖。 如果已对其进行自定义,则应保存现有的 ConfigMap。 在新的 ConfigMap 启动并运行后,您可以重新应用自定义。
如果您在 Kubernetes 1.11 及更高版本中运行 CoreDNS,则在升级期间,将保留现有的 Corefile。
使用 kubeadm 安装 kube-dns 而不是 CoreDNS
注意:
在 Kubernetes 1.11 中,CoreDNS 已经升级到通用可用性(GA),并默认安装。
若要在1.13之前到版本上安装 kube-dns,请将 CoreDNS
特性门值设置为 false
:
kubeadm init --feature-gates=CoreDNS=false
对于 1.13 版和更高版本,请遵循此处概述到指南。
升级 CoreDNS
从 v1.9 起,Kubernetes 提供了 CoreDNS。 您可以在此处检查 Kubernetes 随附的 CoreDNS 版本以及对 CoreDNS 所做的更改。
如果您只想升级 CoreDNS 或使用自己的自定义镜像,则可以手动升级 CoreDNS。
CoreDNS 调优
当涉及到资源利用时,优化内核的配置可能是有用的。有关详细信息,请参阅 关于扩展 CoreDNS 的文档。
接下来
您可以通过修改 Corefile
来配置 CoreDNS,以支持比 ku-dns 更多的用例。有关更多信息,请参考 CoreDNS 网站。