使用Kubernetes运行命令时是否可以指定nodeSelector?
我没有Yaml文件,我只想覆盖nodeSelector。
我尝试了以下操作,但没有成功:
kubectl run myservice --image myserviceimage:latest --overrides='{ "nodeSelector": { "beta.kubernetes.io/os": "windows" } }'
答案 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)
--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下运行该方法存在一些引用问题。