如何访问 Kubernetes 集群上的 kube-scheduler? 使用 kubeadm更新 static pod 清单

问题描述

我正在尝试弄清楚如何使用自定义配置来配置 kubernetes 调度程序,但我在理解调度程序的确切访问方式时遇到了一些麻烦。

调度程序在名为 kube-systemkube-scheduler-it-k8s-master 命名空间下作为 pod 运行。 The documentation 表示您可以通过创建配置文件并调用 kube-scheduler --config <filename> 来配置调度程序。但是我无法直接访问调度程序容器,因为运行 kubectl exec -it kube-scheduler-it-k8s-master -- /bin/bash 返回:

OCI runtime exec failed: exec failed: container_linux.go:370: starting container process caused: exec: "/bin/bash": stat /bin/bash: no such file or directory: unknown
command terminated with exit code 126

我尝试修改 /etc/kubernetes/manifests/kube-scheduler 以在 pod 中挂载我的自定义配置文件,并使用 kube-scheduler 选项集显式调用 --config,但似乎我的更改被还原并且调度程序运行使用默认设置。

我觉得我从根本上误解了 kubernetes 调度程序。我应该从调度程序 pod 本身传入自定义调度程序配置吗?或者这应该以某种方式远程完成?

谢谢!

解决方法

由于您的X problem是“如何修改调度程序配置”,您可以尝试以下操作。


使用 kubeadm

如果您使用 kubeadm 引导集群,则可以在运行 --config 时使用 kubeadm init 标志传递 ClusterConfiguration 类型的自定义配置对象以传递额外参数控制平面组件。

调度程序的示例配置:

$ cat sched.conf
apiVersion: kubeadm.k8s.io/v1beta2
kind: ClusterConfiguration
kubernetesVersion: v1.16.0
scheduler:
  extraArgs:
    address: 0.0.0.0
    config: /home/johndoe/schedconfig.yaml
    kubeconfig: /home/johndoe/kubeconfig.yaml
$ kubeadm init --config sched.conf

您也可以尝试 kubeadm upgrade apply --config sched.conf <k8s version> 在实时集群上应用更新的配置。

参考:https://kubernetes.io/docs/setup/production-environment/tools/kubeadm/control-plane-flags/


更新 static pod 清单

您也可以编辑 /etc/kubernetes/manifests/kube-scheduler.yaml,修改标志以传递配置。确保通过更新 volumesvolumeMounts 部分将文件挂载到 pod 中。

spec:
  containers:
  - command:
    - kube-scheduler
    - --authentication-kubeconfig=/etc/kubernetes/scheduler.conf
    - --authorization-kubeconfig=/etc/kubernetes/scheduler.conf
    - --bind-address=127.0.0.1
    - --kubeconfig=/etc/kubernetes/scheduler.conf
    - --leader-elect=true
    - --config=/etc/kubernetes/mycustomconfig.conf
    volumeMounts:
    - mountPath: /etc/kubernetes/scheduler.conf
      name: kubeconfig
      readOnly: true
    - mountPath: /etc/kubernetes/mycustomconfig.conf
      name: customconfig
      readOnly: true
  volumes:
  - hostPath:
      path: /etc/kubernetes/scheduler.conf
      type: FileOrCreate
    name: kubeconfig
  - hostPath:
      path: /etc/kubernetes/mycustomconfig.conf
      type: FileOrCreate
    name: customconfig

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...