Kubernetes (十四) 调度策略

一.  调度策略                                                                                                                  

二.  调度方法

        nodeName    

                创建pod配置文件          vim nodename.yaml

apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  containers:
  - name: nginx
    image: nginx
  nodeName: k8s4                #找不到节点pod会出现pending

  回收: kubectl delete -f nodename.yaml

        nodeSelector  

                     创建pod配置文件                        vim nodeselector.yaml

apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
  nodeSelector:
    disktype: ssd

   kubectl label  nodes k8s4 disktype=ssd   文件外命令方式打标签

      #取消标签不会影响已经创建好的pod 

     取消标签命令: kubectl label nodes k8s4 disktype-

    回收: kubectl delete -f nodeselector.yaml

     三.  亲和与反亲和                                                                                             

      Pod与节点之间的调度      

                        创建pod配置文件       vim nodeaffinity.yaml

apiVersion: v1
kind: Pod
metadata:
  name: node-affinity
spec:
  containers:
  - name: nginx
    image: nginx
  affinity:
    nodeAffinity:
      requiredDuringSchedulingIgnoredDuringExecution:  #必须满足的
           nodeSelectorTerms:
           - matchExpressions:
             - key: disktype
               operator: In  #以下列表
               values:
                 - ssd
                 - fc

      preferredDuringSchedulingIgnoredDuringExecution:  #倾向满足的
      - weight: 1                                  #权重
        preference:
          matchExpressions:
          - key: kubernetes.io/hostname
            operator: NotIn              #不在列表内
            values:
            - k8s3                       #尽量不去这个节点

     回收: kubectl delete -f nodeaffinity.yaml

    Pod与Pod之间的调度     

                  创建pod亲和性文件    vim podaffinity.yaml

apiVersion: apps/v1
kind: Deployment           #控制器
metadata:
  name: nginx-deployment    #控制器名字
  labels:                   #标签
    app: nginx              #名字
spec:
  replicas: 3              #副本数量
  selector:
    matchLabels:           #匹配标签
      app: nginx           #有这个标签的
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx
      affinity:
        podAffinity:        #pod亲和性
          requiredDuringSchedulingIgnoredDuringExecution:
          - labelSelector:
              matchExpressions:
              - key: app
                operator: In
                values:
                - nginx
            topologyKey: "kubernetes.io/hostname"

        此时所有pod都在一个节点上

       回收:kubectl delete -f podaffinity.yaml

               创建pod反亲和性文件         vim podantiaffinity.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  labels:
    app: nginx
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx
      affinity:
        podAntiAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
          - labelSelector:
              matchExpressions:
              - key: app
                operator: In
                values:
                - nginx
            topologyKey: "kubernetes.io/hostname"

           创建的pod无法在同一个节点


       回收: kubectl delete -f podantiaffinity.yaml

 四. 污点                                                                                                                            

              1.  创建pod配置文件               vim taint.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: web
  name: web
spec:
  replicas: 3
  selector:
    matchLabels:
      app: web
  template:
    metadata:
      labels:
        app: web
    spec:
      containers:
      - image: nginx
        name: nginx

          正常调度到3.4两个没有污点的节点

        2. 开始设置taint污点   NoSchedule 原来运行的pod不受影响

        3.更改taint污点类型    NoExecute  所有pod都会到没有污点的节点

       回收:kubectl delete  -f taint.yaml

         设置 tolerations容忍 

             创建编辑文件               vim taint.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: web
  name: web
spec:
  replicas: 6
  selector:
    matchLabels:
      app: web
  template:
    metadata:
      labels:
        app: web
    spec:
      tolerations:                   #容忍
      - operator: Exists        #存在的污点
        effect: NoSchedule    #污点类型    注释此选项及容忍所有污点
      containers:
      - image: nginx
        name: nginx

      此时有NoSchedule污点的2节点也参与调度  因为3节点是NoExecute污点不参与

        注释掉这个即可都参与调度

              回收:   kubectl delete -f taint.yaml

 记得去除污点: kubectl taint  node k8s3 k1-

     

    cordon停止调度示例   

 kubectl create deployment demo --image nginx --replicas 3

 kubectl cordon k8s3

 kubectl get node

 kubectl scale deployment demo --replicas 6

  恢复: kubectl uncordon k8s3 

   drain驱离节点示例  

  kubectl drain k8s3 --ignore-daemonsets

          delete删除节点     

 kubectl delete nodes k8s3

恢复 :k8s3节点重启kubelet服务重新加入集群

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

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

相关文章

23 SEMC外扩SDRAM

文章目录 23.1 SDRAM 控制原理23.2 SEMC 简介 23.1 SDRAM 控制原理 RT1052 系列芯片扩展内存时可以选择 SRAM 和 SDRAM 由于 SDRAM 的“容量/价格”比较高,即使用 SDRAM 要比 SRAM 要划算得多。 给 RT1052 芯片扩展内存与给 PC 扩展内存的原理是一样的 PC 上一般…

【计算机网络】HTTP协议以及简单的HTTP服务器实现

文章目录 一、HTTP协议1.认识URL2.urlencode和urldecode3.HTTP协议格式4.HTTP的方法5.HTTP的状态码6.HTTP常见Header7.重定向8.长连接9.会话保持10.基本工具 二、简单的HTTP服务器实现1.err.hpp2.log.hpp3.procotol.hpp4.Sock.hpp5.Util.hpp6.httpServer.hpp7.httpServer.cc8.总…

网络编辑day4

思维导图 广播模型发送端-->类似于UDP客户端 #include<head.h> int main(int argc, const char *argv[]) {//1、创建套接字int sfdsocket(AF_INET,SOCK_DGRAM,0);if(sfd-1){perror("socket error ");return -1;}//2、将套接字设置成允许广播int broadcast1…

2023年山东省职业院校技能大赛高职组信息安全管理与评估 模块二(正式赛)

2023年山东省职业院校技能大赛高职组信息安全管理与评估 模块二 模块二竞赛项目试题 根据信息安全管理与评估技术文件要求&#xff0c;模块二为网络安全事件响应、数字取证调查和 应用程序安全。本文件为信息安全管理与评估项目竞赛-模块二试题。 介绍 竞赛有固定的开始和结…

0.96寸OLED-单独驱动和U8g2驱动-硬件软件IIC

0.96寸OLED-单独驱动和U8g2驱动-硬件软件IIC 博主平时DIY经常使用OLED&#xff0c;其中以4脚的I2C屏最多&#xff0c;就想着总结一下子&#xff0c;让广大DIY朋友更容易找到资源。 驱动采用的时SSD1306 同学们拿到代码后&#xff0c;可以直接用&#xff0c;其中博主给的代码默认…

Windows 常用快捷键

文章目录 前言Win R&#xff1a;打开运行窗口Win D&#xff1a;显示桌面。Win E&#xff1a;打开资源管理器。Ctrl Shift Esc&#xff1a;打开任务管理器。Alt Tab&#xff1a;切换当前打开的窗口。F2&#xff1a;重命名选定的文件或文件夹。Ctrl W&#xff1a;关闭当前…

学习响应式编程中遇到的奇奇怪怪的问题

spring项目无法启动 Description: Web application could not be started as there was no org.springframework.boot.web.reactive.server.ReactiveWebServerFactory bean defined in the context. Action: Check your application’s dependencies for a supported react…

【GitHub项目推荐--AI杀入斗地主领域】【转载】

AlphaGo&#xff1a;第一个战胜围棋世界冠军的人工智能机器人。 我不会玩围棋&#xff0c;没办法和 AlphaGO 对局。但是我喜欢玩斗地主&#xff0c;有斗地主人工智能机器人吗&#xff1f; 有&#xff0c;而且还开源了。DouZero&#xff1a;快手团队开发的斗地主AI。别的不说&…

文件共享服务(一)——DAS、NAS、SAN存储类型

一、存储类型 存储类型主要有三种 1. DAS直连式存储 通常由数据线直连电脑就可以用&#xff0c;比如一块新硬盘&#xff0c;只需要利用磁盘模拟器分区&#xff0c;创建文件系统&#xff0c;挂载就可以使用了。 PC中的硬盘或只有一个外部SCSI接口的JBOD存储设备&#xff08;即…

编程框架概述:MVC, MVP, MVVM, Flux/Redux, 和 Clean Architecture

前言 在软件开发中&#xff0c;选择合适的编程框架和架构模式对于构建可维护和可扩展的应用程序至关重要。初学者在面对多种架构选项时可能会感到困惑。本文将详细介绍五种流行的编程框架&#xff1a;MVC、MVP、MVVM、Flux/Redux和Clean Architecture。 MVC&#xff08;Model-V…

1. JDBC 连库操作的基本流程

根据Mysql JDBC基本操作&#xff0c;我们大概可以总结出JDBC的API。 Driver &#xff1a;jdbc驱动DriverManager&#xff1a;驱动注册类&#xff0c;创建Connection连接Connection&#xff1a;物理连接Statement、PreparedStatement&#xff1a;sql语句ResultSet&#xff1a;结…

【前端学习笔记1】css基础

css可以使页面更漂亮&#xff0c;即美化网页 css&#xff1a;层叠样式表 标签选择器&#xff1a; 类选择器&#xff1a; id只能单次调用&#xff0c;类似人的身份证 css里只要是word里面有的功能&#xff0c;他们都有对应的&#xff0c;不会的时候查一下就行 实现垂直居中:h…

[java数据结构] ArrayList和LinkedList介绍与使用

目录 (一) 线性表 (二) ArrayList 1. ArrayList的介绍 2. ArrayList的常见方法和使用 3. ArrayList的遍历 4. ArrayList的模拟实现 5. ArrayList的优缺点 (三) LinkedList 1. LinkedList的介绍 2. LinkedList的常见方法和使用 3. LinkedList的遍历 4. LinkedList的…

Spring Boot应用程序如何配置 HTTPS 访问方式

在 Spring Boot 应用程序中配置 HTTPS 访问方式可以根据你是否拥有由受信任的证书颁发机构&#xff08;CA&#xff09;签发的证书来分为两种情况&#xff1a;使用自签名证书和使用 CA 签发的证书。下面我将分别介绍这两种情况的配置方法&#xff1a; 使用自签名证书 如果你还…

力扣每日一练(24-1-18)

经验一&#xff1a;不要把问题想复杂 Python&#xff1a; min_price float(inf)max_profit 0for price in prices:min_price min(min_price, price)max_profit max(max_profit, price - min_price)return max_profit C#&#xff1a; public int MaxProfit(int[] prices) {i…

强化学习(二)多臂老虎机 “Multi-armed Bandits”——1

将强化学习与机器学习、深度学习区分开的最重要的特征为&#xff1a;它通过训练中信息来评估所采取的动作&#xff0c;而不是给出正确的动作进行指导&#xff0c;这极大地促进了寻找更优动作的需求。 1、多臂老虎机&#xff08;Multi-armed Bandits&#xff09;问题 赌场的老虎…

WPF入门到跪下 第十一章 Prism(一)数据处理

官网&#xff1a;https://primslibrary.com 源码地址&#xff1a;https://guthub.com/PrismLibrary/prism Prism是由微软发布、维护的开源框架&#xff0c;提供了一组设计模式的实现&#xff0c;有助于编写结构良好的且可维护的XAML应用程序&#xff0c;包括MVVM、依赖注入、命…

关于数字孪生技术在医院的应用场景和未来趋势

数字孪生技术是一种新兴的技术&#xff0c;它可以将现实世界中的物体或系统建立为虚拟模型&#xff0c;通过模拟和分析&#xff0c;为现实世界中的物体或系统提供支持和优化。数字孪生技术在医疗领域的应用被称为数字孪生智慧医院技术。数字孪生智慧医院技术是指将数字孪生技术…

git format用法学习

git format-patch -1 <commit-id> -o <保存路径> 是一个用于生成单个提交的补丁文件的 Git 命令。下面是对该命令及其参数的解释&#xff1a; git format-patch: 这是一个用于生成补丁文件的 Git 命令。-1: 这是一个选项&#xff0c;表示只生成指定提交&#xff0…

vivado 调试设计

调试设计 概述 FPGA设计的调试是一个多步骤的迭代过程。就像大多数复杂的问题一样最好将FPGA设计调试过程分解为更小的部分&#xff0c;例如&#xff0c;通过专注于使设计工作的一小部分发挥作用&#xff0c;而不是试图使整体发挥作用一次完成设计工作。经过验证的设计和调试…