Kubectl运行集nodeSelector

时间:2018-07-03 19:23:00

标签: kubernetes

使用Kubernetes运行命令时是否可以指定nodeSelector?

我没有Yaml文件,我只想覆盖nodeSelector。

我尝试了以下操作,但没有成功:

kubectl run myservice --image myserviceimage:latest --overrides='{ "nodeSelector": { "beta.kubernetes.io/os": "windows" } }'

5 个答案:

答案 0 :(得分:5)

我现在有一个实际的答案... 这是我的最终答案

为了通过run命令指定节点选择器(并使之运行,使其在特定节点上运行),我们可以执行以下操作:

0)确保要定位的节点可以在其上调度Pod。我的主节点(master-0)对此没有准备,所以我不得不通过以下命令删除其污点:

kubectl taint node master-0 node-role.kubernetes.io/master:NoSchedule-

(尾随-很重要),如果需要,则将master-0替换为您的名字。

1)将override命令添加到kubectl run命令。

run hello-world --replicas=1 --labels="run=load-balancer-example" --image=gcr.io/google-samples/node-hello:1.0  --port=8080 --overrides='{ "apiVersion": "apps/v1beta1", "spec": { "template": { "spec": { "nodeSelector": { "kubernetes.io/hostname": "master-0" } } } } }'

*确保您的apiVersion受支持...当我尝试使用v1时出现以下错误:

  

错误:没有为版本“ v1”注册任何类型的“部署”

要克服这一点,我运行了命令:

kubectl api-versions

并在此线程的推动下,https://github.com/kubernetes/kubernetes/issues/55894选择了“ apps / v1beta1”

我不确定上面的答案如何工作,因为它们在json中没有足够的封装...也不知道如何:https://github.com/kubernetes/kubernetes/issues/45153起作用,对我来说问题是:

我缺少的关键是:它不是.spec.nodeSelector,必须是.spec.template.spec.nodeSelector

答案 1 :(得分:1)

kubectl run documentation提到:

--overrides="": 
  

对生成的对象的内联JSON覆盖。
  如果这是非空的,则用于覆盖生成的对象。
  要求对象提供valid apiVersion field

所以至少尝试:

--overrides='{ "apiVersion": "v1", "nodeSelector"... }'

如果这样不起作用,请检查实际生成的Yaml(来自issue 24873);

for n in $(kubectl get -o=name pvc,configmap,serviceaccount,secret,ingress,service,deployment,statefulset,hpa,job,cronjob)
do
    mkdir -p $(dirname $n)
    kubectl get -o=yaml --export $n > $n.yaml
done

答案 2 :(得分:1)

尝试一下:

LocationUtil

答案 3 :(得分:1)

nodeSelector必须用spec包装。像这样

kubectl run --generator=run-pod/v1 -ti --rm test --image=ubuntu:18.04 --overrides='{"spec": { "nodeSelector": {"nodename": "eks-prod-4"}}}'

答案 4 :(得分:0)

在Kubernetes 1.12和更高版本中,匹配规则已更改为使用nodeAffinity。

kubectl run hello-world --replicas=1 --labels="run=load-balancer-example" --image=gcr.io/google-samples/node-hello:1.0  --port=8080 --overrides='{"apiVersion":"v1","spec":{"affinity":{"nodeAffinity":{"requiredDuringSchedulingIgnoredDuringExecution":{"nodeSelectorTerms":[{"matchFields":[{"key":"metadata.name","operator":"In","values":["my-chosen-node-01"]}]}]}}}}}'

请注意,这种方法在Shell之类的Unix上可以正常工作,但是在Windows的PowerShell下运行该方法存在一些引用问题。