K8S之运用节点选择器指定Pod运行的节点

node节点选择器的使用

  • 使用场景
  • 实践
    • 使用nodeName
    • 使用nodeSelector
    • nodeName和nodeSelector混合使用
      • 1、设置了nodeName 和 设置 Node上都不存在的标签。看调度情况
      • 2、设置nodeName 为node1 和 设置 node2上才有的标签。看调度情况
    • 实践总结

使用场景

默认情况,在创建Pod资源的时候,会根据schduler进行节点调度,默认会随机调度一个工作节点。

如果想要Pod 调度到指定节点 或者 调度到一些具有相同特点的node节点,就可以运用Pod中的 nodeName 或者 nodeSelector 字段指定要调度到的Node节点。

实践

使用nodeName

运用nodeName,将Pod运行在指定Node上

创建pod资源文件

vim pod-node-name.yaml
apiVersion: v1
kind: Pod
metadata:name: pod-node-namenamespace: test # 指定命名空间
spec:nodeName: k8s-node1 # 指定pod运行的节点名称containers:- name:  tomcat-javaimage: tomcat:8.5-jre8-alpineimagePullPolicy: IfNotPresentports:- containerPort: 8080

创建资源

kubectl apply -f pod-node-name.yaml

查看创建的pod调度到哪个节点

kubectl get pods -n test -o wide

看pod的详细信息

kubectl describe pods pod-node-name -n test

使用nodeSelector

运用nodeSelector,指定Pod调度到具有哪些 标签 的Node节点上

看Node节点的标签

kubectl get nodes --show-labels

在这里插入图片描述

指定创建的Pod要调度到具有node-type=worker标签的node上
(ps. 以下操作顺序:先建Pod再给Node打上标签)

创建pod资源文件

vim pod-node-selector.yaml
apiVersion: v1
kind: Pod
metadata:name: pod-node-selectornamespace: test # 指定命名空间
spec:nodeSelector:node-type: workercontainers:- name:  tomcat-javaports:- containerPort: 8080image: tomcat:8.5-jre8-alpineimagePullPolicy: IfNotPresent

创建资源

kubectl apply -f pod-node-selector.yaml

查看创建的pod调度到哪个节点

kubectl get pods -n test -o wide

在这里插入图片描述

看pod的详细信息

kubectl describe pods pod-node-selector -n test

在这里插入图片描述

找不到符合标签的node,pod一直处于创建中

给Node名为 k8s-node2 的节点打个具有 “node-type=worker” 的标签

kubectl label nodes k8s-node2 node-type=worker

Node节点上打标签后,再看 Pod状态 和 调度的节点

kubectl get pods -n test -o wide

在这里插入图片描述
找到符合的node节点后,成功运行

nodeName和nodeSelector混合使用

1、设置了nodeName 和 设置 Node上都不存在的标签。看调度情况

创建pod资源文件

vim pod-node-mix1.yaml
apiVersion: v1
kind: Pod
metadata:name: pod-node-mix1namespace: test # 指定命名空间
spec:nodeName: k8s-node2nodeSelector:node-type: backupcontainers:- name:  tomcat-javaports:- containerPort: 8080image: tomcat:8.5-jre8-alpineimagePullPolicy: IfNotPresent

创建资源

kubectl apply -f pod-node-mix1.yaml

再查看pod

kubectl get pods -n test -o wide

在这里插入图片描述

同一个yaml文件里定义Pod资源,如果同时定义了 nodeName 和 nodeSelector,那么条件必须都满足,有一个不满足都会调度失败

再给Node名为 k8s-node2 的节点打上标签

kubectl label nodes k8s-node2 node-type=backup

重建pod

kubectl delete pods pod-node-mix1 -n testkubectl apply -f pod-node-mix1.yaml

pod就能正常调度到k8s-node2上

kubectl get pods -n test -owide

在这里插入图片描述

2、设置nodeName 为node1 和 设置 node2上才有的标签。看调度情况

创建pod资源文件

vim pod-node-mix2.yaml
apiVersion: v1
kind: Pod
metadata:name: pod-node-mix2namespace: test # 指定命名空间
spec:nodeName: k8s-node1nodeSelector:node-type: backupcontainers:- name:  tomcat-javaports:- containerPort: 8080image: tomcat:8.5-jre8-alpineimagePullPolicy: IfNotPresent

创建资源

kubectl apply -f pod-node-mix2.yaml

查看pod调度到哪个节点

kubectl get pods -n test -owide

在这里插入图片描述

看pod的详细信息

kubectl describe pods pod-node-mix2 -n test

在这里插入图片描述

找节点调度时,同时设置了nodeName和nodeSelector,nodeName调度的优先级最高
但Pod状态还是非running,尽量不要同时使用nodeName和nodeSelector

实践总结

  • 同时设置了nodeName和nodeSelector,nodeName优先级最高
  • 如果同时定义了 nodeName 和 nodeSelector,那么条件必须都满足,否则会调度失败
  • 只设置了nodeSelector,当找不到符合标签的node,pod一直处于创建中

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/256365.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

故障诊断 | 一文解决,TCN时间卷积神经网络模型的故障诊断(Matlab)

效果一览 文章概述 故障诊断 | 一文解决,TCN时间卷积神经网络模型的故障诊断(Matlab) 模型描述 时间卷积神经网络(TCN)是一种用于序列数据建模和预测的深度学习模型。它通过卷积操作在时间维度上对序列数据进行特征提取,并且可以处理可变长度的输入序列。 要使用TCN进行…

vue-组件组成和组件通信(四)

组件的三大组成部分 (结构/样式/逻辑) scoped样式冲突 默认情况:写在组件中的样式会 全局生效 → 因此很容易造成多个组件之间的样式冲突问题。 1. 全局样式: 默认组件中的样式会作用到全局 2. 局部样式: 可以给组件加上 scoped 属性, 可以让样式只作用于当前组…

nginx添加lua模块

目录 已安装了nginx,后追加lua模块nginx 重新编译知识参考: 从零安装一、首先需要安装必要的库(pcre、zlib、openssl)二、安装LUA环境及相关库 (LuaJIT、ngx_devel_kit、lua-nginx-module)注意:…

基于YOLOv8的暗光低光环境下(ExDark数据集)检测,加入多种优化方式---DCNv4结合SPPF ,助力自动驾驶(一)

💡💡💡本文主要内容:详细介绍了暗光低光数据集检测整个过程,从数据集到训练模型到结果可视化分析,以及如何优化提升检测性能。 💡💡💡加入 DCNv4结合SPPF mAP0.5由原始的0.682提升至…

牛客网SQL进阶114:更新记录

官网链接: 更新记录(二)_牛客题霸_牛客网现有一张试卷作答记录表exam_record,其中包含多年来的用户作答试卷记录,结构如下表。题目来自【牛客题霸】https://www.nowcoder.com/practice/0c2e81c6b62e4a0f848fa7693291d…

Gitlab和Jenkins集成 实现CI (二)

Gitlab和Jenkins集成 实现CI (一) Gitlab和Jenkins集成 实现CI (二) Gitlab和Jenkins集成 实现CI (三) 配置Gitlab api token 配置 Gitlab 进入gitlab #mermaid-svg-t84fR8wrT4sB4raQ {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:…

单例模式:懒汉饿汉线程安全问题

在我们前几篇文章中都了解了一些关于线程的知识,那么在多线程的情况下如何创建单例模式,其中的线程安全问题如何解决? 目录 1.什么是单例模式? (饿汉模式) 2.单例模式(懒汉模式) *懒汉模式与懒汉模式的对比 *如何解决懒汉模式…

【后端高频面试题--SpringBoot篇】

🚀 作者 :“码上有前” 🚀 文章简介 :后端高频面试题 🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬 这里写目录标题 1.什么是SpringBoot?它的主要特点是什么?2.列举一些Spri…

《剑指 Offer》专项突破 - 面试题 43 : 在完全二叉树中添加节点(两种方法 + C++ 实现)

目录 前言 方法一 方法二 前言 题目链接:LCR 043. 完全二叉树插入器 - 力扣(LeetCode) 题目: 在完全二叉树中,除最后一层之外其他层的节点都是满的(第 n 层有 个节点)。最后一层的节点可能…

SQL,HQL刷题,尚硅谷

目录 相关表数据: 题目及思路解析: 汇总分析 1、查询编号为“02”的课程的总成绩 2、查询参加考试的学生个数 分组 1、查询各科成绩最高和最低的分,以如下的形式显示:课程号,最高分,最低分 2、查询每门课程…

springboot179基于javaweb的流浪宠物管理系统的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计,课程设计参考与学习用途。仅供学习参考, 不得用于商业或者非法用途,否则,一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

鸿蒙开发第3篇__大数据量的列表加载性能优化

列表 是最常用到的组件 一 ForEach 渲染控制语法————Foreach Foreach的作用 遍历数组项,并创建相同的布局组件块在组件加载时, 将数组内容数据全部创建对应的组件内容, 渲染到页面上 const swiperImage: Resource[] {$r("app.me…

类与结构体(6)

我们上一起讲了这一期讲存储类和继承,这个难度很大的。 存储类 存储类主要规定了函数和变量的范围,在c中有这些存储类↓: ৹ auto(自动判断函数是什么类型) ৹ register (常用的变量和inline差不多,但应…

Netty应用——通过WebSocket编程实现服务器和客户端长连接(十八)

Http协议是无状态的,浏览器和服务器间的请求响应一次,下一次会重新创建连接要求:实现基于webSocket的长连接的全双工的交互改变Http协议多次请求的约束,实现长连接了, 服务器可以发送消息给浏览器客户端浏览器和服务器端会相互感知…

docker本地目录挂载

小命令 1、查看容器详情 docker inspect 容器名称 还是以nginx为例,上篇文章我们制作了nginx静态目录的数据卷,此时查看nginx容器时会展示出来(docker inspect nginx 展示信息太多,这里只截图数据卷挂载信息)&#…

【附代码】NumPy加速库NumExpr(大数据)

文章目录 相关文献测试电脑配置数组加减乘除数组乘方Pandas加减乘除总结 作者:小猪快跑 基础数学&计算数学,从事优化领域5年,主要研究方向:MIP求解器、整数规划、随机规划、智能优化算法 如有错误,欢迎指正。如有…

CVE-2022-0760 漏洞复现

CVE-2022-0760 NSS [HNCTF 2022 WEEK2]ohmywordpress 【CVE-2022-0760】 题目描述:flag在数据库里面。 开题: 顺着按钮一直点下去会发现出现一个按钮叫安装WordPress 安装完之后的界面,有一个搜索框。 F12看看network。 又出现了这个Wor…

MATLAB知识点:矩阵的除法

​讲解视频:可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇(数学建模清风主讲,适合零基础同学观看)_哔哩哔哩_bilibili 节选自第3章 3.4.2 算术运算 下面我们再来介绍矩阵的除法。事…

【C语言】实现双向链表

目录 (一)头文件 (二) 功能实现 (1)初始化 (2)打印链表 (3) 头插与头删 (4)尾插与尾删 (5)指定位置之后…

DMA直接内存访问,STM32实现高速数据传输使用配置

1、DMA运用场景 随着智能化、信息化的不断推进,嵌入式设备的数据处理量也呈现指数级增加,因此对于巨大的数据量处理的情况时,必须采取其它的方式去替CPU减负,以保证嵌入式设备性能。例如SD卡存储器和音视频、网络高速通信等其它情…