kubernetes (k8s) CKA认证之第二课:亲和性与 Pod 的调度
手动调度一个 pod
// cat manual-schedule.yaml
apiVersion: v1
kind: Pod
metadata:
labels:
run: pod-manual-schedule
name: pod-manual-schedule
namespace: default
spec:
nodeName: "app.centos7.com"
containers:
- name: my-pod
image: nginx:alpine
执行以下命令即可验证。
kubectl create -f manual-schedule.yaml
kubectl get po -owide
kubectl describe po pod-manual-schedule|less
kubectl delete -f manual-schedule.yaml
NodeAffinity 结点的亲和性
kubectl label node app.centos7.com has-eip=yes
kubectl get node --show-labels
vi node-affinity.yaml
apiVersion: v1
kind: Pod
metadata:
labels:
run: node-affinity
name: node-affinity
namespace: default
spec:
containers:
- name: node-affinity
image: nginx:alpine
imagePullPolicy: IfNotPresent
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: has-eip
operator: In
values:
- "yes"
运行以下命令加以验证:
kubectl create -f node-affinity.yaml
kubectl get po -owide
结果:
[root@svn ch02]# kubectl get po -owide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
node-affinity 1/1 Running 0 5m49s 10.244.2.117 app.centos7.com <none> <none>
[root@svn ch02]#
PodAffinity (保留上一步的 node-affinity 处于 Running 状态 ) “豆荚”的亲和性
vi pod-affinity.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod-affinity
labels:
run: pod-affinity
spec:
containers:
- name: pod-affinity
image: nginx:alpine
affinity:
podAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- labelSelector:
matchExpressions:
- key: run
operator: In
values:
- "node-affinity"
topologyKey: kubernetes.io/hostname
运行结果:
[root@svn ch02]# kubectl get po --show-labels -owide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES LABELS
node-affinity 1/1 Running 0 129m 10.244.2.117 app.centos7.com <none> <none> run=node-affinity
[root@svn ch02]# kubectl create -f pod-affinity.yaml
pod/pod-affinity created
[root@svn ch02]# kubectl get po --show-labels -owide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES LABELS
node-affinity 1/1 Running 0 129m 10.244.2.117 app.centos7.com <none> <none> run=node-affinity
pod-affinity 1/1 Running 0 4s 10.244.2.118 app.centos7.com <none> <none> run=pod-affinity
[root@svn ch02]#
pod-anti-affinity 反亲和性
前提:保留上一步的 node-affinity 和 pod-affinity 处于 Running 状态
vi pod-anti-affinity.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod-anti-affinity
labels:
run: pod-anti-affinity
spec:
containers:
- name: pod-affinity
image: nginx:alpine
affinity:
podAntiAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- labelSelector:
matchExpressions:
- key: run
operator: In
values:
- "pod-affinity"
topologyKey: kubernetes.io/hostname
由于反亲和性,新生成的 pod-anti-affinity 将会被调度到 app.centos7.com 之外的结点。
运行结果:
[root@svn ch02]# kc create -f pod-anti-affinity.yaml
pod/pod-anti-affinity created
[root@svn ch02]# kc get pod -owide --show-labels
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES LABELS
node-affinity 1/1 Running 0 153m 10.244.2.117 app.centos7.com <none> <none> run=node-affinity
pod-affinity 1/1 Running 0 24m 10.244.2.118 app.centos7.com <none> <none> run=pod-affinity
pod-anti-affinity 1/1 Running 0 3m18s 10.244.1.9 jks.centos7.com <none> <none> run=pod-anti-affinity
[root@svn ch02]#
Taints 与 Tolerations 污点与容忍
// 为 master 节点配置 taints 禁止普通 pod 调度到 master 上
kubectl taint nodes svn.centos7.com node-role.kubernetes.io/master=:NoSchedule
vi pod-tolerations.yaml
apiVersion: v1
kind: Pod
metadata:
labels:
run: pod-tolerations
name: pod-tolerations
spec:
containers:
- name: my-pod
image: nginx:alpine
tolerations:
- key: gpu
operator: Equal
value: "yes"
effect: NoSchedule
给 node jks.centos7.com 增添对应的污点,如此,pod-tolerations 才可被调度在其之上。
kubectl taint node jks.centos7.com gpu=no:NoSchedule
kubectl taint node jks.centos7.com gpu=yes:NoSchedule --overwrite
运行结果:
[root@svn ch02]# kubectl create -f pod-tolerations.yaml
pod/pod-tolerations created
[root@svn ch02]# kubectl get po -owide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
pod-tolerations 1/1 Running 0 9s 10.244.1.18 jks.centos7.com <none> <none>
[root@svn ch02]#
References
kubernetes (k8s) CKA认证之第二课:亲和性与 Pod 的调度的更多相关文章
- Kubernetes/K8s CKA认证全套实训视频教程下载
地址: 链接:https://pan.baidu.com/s/1bwEUZTCVzqM3mGjrlISbcg 提取码:r1kx 目录: 目录: │ 1-1.kubernetes理论教程 - 云原生技术 ...
- Kubernetes K8S之通过helm部署metrics-server与HPA详解
Kubernetes K8S之通过helm部署metrics-server与 Horizontal Pod Autoscaling (HPA)详解 主机配置规划 服务器名称(hostname) 系统版 ...
- Kubernetes K8S之affinity亲和性与反亲和性详解与示例
Kubernetes K8S之Node节点亲和性与反亲和性以及Pod亲和性与反亲和性详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-mas ...
- 《两地书》--Kubernetes(K8s)基础知识(docker容器技术)
大家都知道历史上有段佳话叫“司马相如和卓文君”.“皑如山上雪,皎若云间月”.卓文君这么美,却也抵不过多情女儿薄情郎. 司马相如因一首<子虚赋>得汉武帝赏识,飞黄腾达之后便要与卓文君“故来相 ...
- 我如何通过K8S开发认证(CKAD)考试
题记:笔者最近经过3个多月的空余时间准备,终于通过了K8S开发认证(CKAD)的考试,在这里简单给大家分享一下经验. 一,先科普下CKAD 众所周知,Kubernetes在容器编排器大战中脱颖而出后, ...
- Docker Kubernetes(K8s)简介
入职了新公司,使用了Docker和K8s,需要有一个基础的了解,对网络上相关信息进行了简单总结. 一Docker 1简介: Docker 将应用程序与该程序的依赖,打包在一个文件里面.运行这个文件,就 ...
- Kubernetes(k8s) docker集群搭建
原文地址:https://blog.csdn.net/real_myth/article/details/78719244 一.Kubernetes系列之介绍篇 •Kubernetes介绍 1.背 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之flanneld网络介绍及部署(三)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.flanneld介绍 ...
- k8s的认证和service account简述
k8s的认证: 与API server通信的客户端大致有两类: 1.集群客户端工具(kubectl.kubeadm.kubelet等) 2.集群内pod. 任何客户端访问k8s时的过程: 1.认 ...
随机推荐
- JDK的简介,卸载和安装过程
JDK的简介,卸载和安装过程 JDK JRE JVM JDK:Java Development Kit JRE:Java Runtime Environment JVM:Java Virtual Ma ...
- 企业级BI是自研还是采购?
企业级BI是自研还是采购? 上一篇<企业级BI为什么这么难做?>,谈到了企业级BI项目所具有的特殊背景,以及在"破局"方面的一点思考,其中谈论的焦点主要是在IT开发项目 ...
- C#.NET编程小考30题错题纠错
1)以下关于序列化和反序列化的描述错误的是( C). a) 序列化是将对象的状态存储到特定存储介质中的过程 b) 二进制格式化器的Serialize()和Deserialize()方法可以分别用来实现 ...
- Redis持久化 aof和rdb的原理配置
目录 一.介绍 二.RDB持久化(全量写入) rdb原理 rdb模式 rdb触发情况 rdb优势和劣势 rdb文件配置 rdb命令配置 rdb数据恢复 三.AOF持久化(增量写入) aof原理 aof ...
- Python用pandas获取Excel数据
import pandas as pd df1 = pd.DataFrame(pd.read_excel(r'C:\python测试文件\我的三国啊.xlsx',sheet_name='Sheet1' ...
- php-正则邮箱验证及详解
当前的邮箱格式有哪些//1.第1种是QQ邮箱,它的后缀名是,@qq, .com.// 2.第2种是网易邮箱后缀名是,@163.com或者,@126.com// 3.第3种是雅虎邮箱,后缀名是,@yah ...
- 36、有效的数独 | 算法(leetode,附思维导图 + 全部解法)300题
零 标题:算法(leetode,附思维导图 + 全部解法)300题之(36)有效的数独 前言 1)码农三少 ,一个致力于 编写极简.但齐全题解(算法) 的博主. 2)文末附赠 价值上百美刀 资料. 一 ...
- 如何把myeclipse的工程导入到svn服务器上
如何把myeclipse的工程导入到svn服务器上,按照如下步骤便可
- JAVA获取多个经纬度的中心点
import java.util.LinkedList; public class Test1 { /** * 位置实体类,根据自己的来即可 */ static class Position{ /** ...
- ByteBuddy代码生成技术
简介 如官网所说Byte Buddy 是一个代码生成和操作库,用于在Java应用程序运行时创建和修改Java类,而无需编译器的帮助.除了Java类库附带的代码生成实用程序外,Byte Buddy还允许 ...