K8S将pod调度到指定nodes上运行

两种方式
方式1:强制固定
编写yaml,添加参数(node节点名)
vim text.yaml
nodeName: worker01  #添加节点名参数
具体yaml
apiVersion: v1
kind: Pod
metadata:
  name: text
  namespace: text
spec:
  nodeName: worker01   #添加节点名参数
  containers:
  - name: hello
    image: centos:7
    imagePullPolicy: IfNotPresent
    command: ["bash","-c","--"]
    args: ["while true; do sleep 3;done;"]
创建该pod
kubectl create -f text.yaml

在这里插入图片描述

查看pod,运行成功

在这里插入图片描述

查看是否在worker01上运行
kubectl describe pod text -n text

在这里插入图片描述

方式2:使用标签选择器(label-selector)
给节点添加标签
kubectl label nodes worker03 type=node_type

在这里插入图片描述

查看标签是否添加成功
kubectl get node --show-labels   #获取所有节点的标签,得到worker03设置的标签

在这里插入图片描述

编写yaml创建pod,添加标签选择器参数
vim text1.yaml
内容如下
apiVersion: v1
kind: Pod
metadata:
  name: text1
  namespace: text
spec:
  nodeSelector:    #标签选择器参数
    type: node_type #刚刚添加的类型
  containers:
  - name: hello1
    image: centos:7
    imagePullPolicy: IfNotPresent
    command: ["bash","-c","--"]
    args: ["while true; do sleep 3;done;"]

在这里插入图片描述

查看是否运行
kubectl get pod -n text

在这里插入图片描述

查看是否成功在worker03上运行
kubectl describe pod text1 -n text

在这里插入图片描述
原文链接:http://www.hainiubl.com/topics/75623

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐