此页面展示如何启用和配置集群中 DNS 服务的自动伸缩。
To check the version, enter kubectl version
.
Make sure the DNS feature itself is enabled.
Kubernetes version 1.4.0 or later is recommended. –>
您必须拥有一个 Kubernetes 集群,并且必须使用 kubectl 命令行工具与你的集群进行通信。如果您还没有一个集群,您可以通过 Minikube 创建一个集群,或者使用这些 Kubernetes playground :
To check the version, enter kubectl version
.
确保 DNS 特性是启用的。
推荐使用 Kubernetes 1.4.0 或更高版本。
列出集群中命名空间 kube-system 下的 Deployment:
kubectl get deployment --namespace=kube-system
输出类似:
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
...
dns-autoscaler 1 1 1 1 ...
...
如果在输出中看到 dns-autoscaler
,则表示已启用 DNS 水平自动缩放,
可以跳过阅读优化自动缩放参数章节。
列出集群中命名空间 kube-system 下的 Deployment:
kubectl get deployment --namespace=kube-system
在早于 1.12 的 Kubernetes 版本中,DNS Deployment 称之为 kube-dns
。
在 Kubernetes 1.5 之前的版本中,DNS 是使用 ReplicationController 而不是 Deployment 来实现的。 因此,如果在前面的输出中没有看到 kube-dns 或类似的名称,请在 kube-system 名称空间中列出集群中的 ReplicationControllers:
kubectl get rc --namespace=kube-system
输出类似:
NAME DESIRED CURRENT READY AGE
...
kube-dns-v20 1 1 1 ...
...
如果是 DNS Deployment,则伸缩目标是:
Deployment/<your-deployment-name>
其中,
如果是 DNS ReplicationController,则伸缩目标是:
ReplicationController/<your-rc-name>
其中,
在本节中,您将创建一个 Deployment。Deployment 中的 Pod 根据 cluster-proportional-autoscaler-amd64
镜像运行容器。
创建一个名为 dns-horizontal-autoscaler.yaml
的文件内容如下:
admin/dns/dns-horizontal-autoscaler.yaml
|
---|
|
在文件中,将 <SCALE_TARGET>
替换为扩缩目标。
转至包含配置文件的目录,然后输入以下命令以创建 Deployment:
kubectl create -f dns-horizontal-autoscaler.yaml
运行成功后的输出结果为:
deployment.apps/kube-dns-autoscaler created
现在启用了 DNS 水平自动扩缩。
验证 dns-autoscaler ConfigMap 存在:
kubectl get configmap --namespace=kube-system
输出类似:
NAME DATA AGE
...
dns-autoscaler 1 ...
...
修改 ConfigMap 中的数据:
kubectl edit configmap dns-autoscaler --namespace=kube-system
寻找这一行:
linear: '{"coresPerReplica":256,"min":1,"nodesPerReplica":16}'
根据需要修改字段。min
字段表示 DNS 后端的最小数量。实际后端数的计算公式为:
replicas = max( ceil( cores * 1/coresPerReplica ) , ceil( nodes * 1/nodesPerReplica ) )
注意,coresPerReplica
和 nodesPerReplica
的值都是整数。
其思想是,当集群使用具有多个核心的节点时,coresPerReplica
占主导地位。
当集群使用内核较少的节点时,nodesPerReplica
占主导地位。
还有其他受支持的扩展模式。有关详细信息,请参见 cluster-proportion -autoscaler。
有一些选项可用于调优 DNS 水平自动扩缩。使用哪个选项取决于不同的条件。
此选项适用于所有情况。输入这个命令:
kubectl scale deployment --replicas=0 dns-autoscaler --namespace=kube-system
输出是:
deployment.extensions/dns-autoscaler scaled
验证副本计数是否为零:
kubectl get deployment --namespace=kube-system
输出在 DESIRED 和 CURRENT 列中显示 0:
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
...
dns-autoscaler 0 0 0 0 ...
...
如果 dns-autoscaler 在您自己的控制之下,则此选项有效,这意味着没有人会重新创建它:
kubectl delete deployment dns-autoscaler --namespace=kube-system
输出是:
deployment.extensions "dns-autoscaler" deleted
此选项可行的前提是,dns-autoscaler 在附加组件管理器 的控制之下, 并且有对主节点的写访问权。
登录主节点并删除相应的清单文件。这个 dns-autoscaler 的通用路径是:
/etc/kubernetes/addons/dns-horizontal-autoscaler/dns-horizontal-autoscaler.yaml
删除清单文件后,附加组件管理器将删除 dns-autoscaler Deployment。
了解 DNS 水平自动缩放的工作原理
集群比例自动伸缩器应用程序与 DNS 服务分开部署。
一个自动伸缩 Pod 运行一个客户端,该客户端轮询 Kubernetes API 服务器以获得集群中的节点和核心的数量。
根据当前可调度节点和核心以及给定的缩放参数,计算并应用所需的副本计数到 DNS 后端。
缩放参数和数据点是通过 ConfigMap 提供给 autoscaler 的,它会在每个轮询间隔刷新参数表,以更新所需的最新缩放参数。
允许在不重新构建或重新启动自动缩放Pod的情况下更改缩放参数。
autoscaler 提供了一个控制器接口来支持两种控制模式:linear 和 *ladder*。
除了线性和梯形之外,未来将考虑自定义度量的控制模式。
基于 DNS 特定指标的 DNS 后端扩展正在考虑作为未来发展。当前实现使用集群中的节点和核心数量是有限的。
未来将考虑支持类似于水平 Pod 自动伸缩
了解更多关于实施 of cluster-proportional-autoscaler。
此页是否对您有帮助?
Thanks for the feedback. If you have a specific, answerable question about how to use Kubernetes, ask it on Stack Overflow. Open an issue in the GitHub repo if you want to report a problem or suggest an improvement.