十一、kubernetes核心技术Label详解、实例

1、概述

 

        Label是kubernetes系统中的一个重要概念。它的作用就是在资源上添加标识,用来对它们进行区分和选择。

        Label的特点:

  • 一个Label会以key/value键值对的形式附加到各种对象上,如Node、Pod、Service等等
  • 一个资源对象可以定义任意数量的Label ,同一个Label也可以被添加到任意数量的资源对象上去

  • Label通常在资源对象定义时确定,当然也可以在对象创建后动态添加或者删除

        可以通过Label实现资源的多维度分组,以便灵活、方便地进行资源分配、调度、配置、部署等管理工作。

        一些常用的Label 示例如下:

  • 版本标签:"version":"release", "version":"stable"......
  • 环境标签:"environment":"dev","environment":"test","environment":"pro"
  • 架构标签:"tier":"frontend","tier":"backend"

标签定义完毕之后,还要考虑到标签的选择,这就要使用到Label Selector(标签选择器),即:

Label用于给某个资源对象定义标识

Label Selector用于查询和筛选拥有某些标签的资源对象

当前有两种Label Selector:

  • 基于等式的Label Selector

name = slave: 选择所有包含Label中key="name"且value="slave"的对象

env != production: 选择所有包括Label中的key="env"且value不等于"production"的对象

  • 基于集合的Label Selector

name in (master, slave): 选择所有包含Label中的key="name"且value="master"或"slave"的对象

name not in (frontend): 选择所有包含Label中的key="name"且value不等于"frontend"的对象

标签的选择条件可以使用多个,此时将多个Label Selector进行组合,使用逗号","进行分隔即可。例如:

name=slave,env!=production

name not in (frontend),env!=production

2、命令行操作Label实例

2.1、为deploy打标签

#创建开发环境命名空间 dev
kubectl create ns dev

#在dev命名空间创建 deploy   mynginx
kubectl create deploy mynginx --image=nginx -n dev

#为mynginx 打标签  env=dev
kubectl label deploy mynginx env=dev -n dev

2.2、为deploy更新标签

涉及命令:

#为mynginx 打标签  version=1.0
kubectl label deploy mynginx version=1.0 -n dev

#为mynginx 更新标签 version=2.0
kubectl label deploy mynginx version=2.0 -n dev --overwrite

2.3、查看标签

涉及命令:

kubectl get deploy mynginx -n dev --show-labels

2.4、筛选标签

现在有如下需求:我想知道哪些deploy有标签version=2.0?这个时候就需要用到筛选标签了

涉及命令:

#查看哪些deploy 被打上version=2.0 标签
kubectl get deploy -n dev -l version=2.0 --show-labels

#如果是需要通过多个标签筛选 标签之间以逗号分隔即可
kubectl get deploy -n dev -l version=2.0,app=mynginx --show-labels

2.5、删除标签

涉及命令:

#删除标签  在要删除的标签后面加“-”执行即可
kubectl label deploy mynginx version- -n dev

3、Yaml操作Label实例

我们通过yaml实现2中 创建 deploy 资源,名称为mynginx,增加标签 env=dev,version=2.0

先通过命令生成yaml模板:

#生成mynginx.yaml 然后改造
kubectl create deploy mynginx --image=nginx -n dev -o yaml --dry-run=client > mynginx.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  #在此下增加deploy的标签
  labels:
    app: mynginx
    evn: dev
    versioin: "2.0"
  name: mynginx
  namespace: dev
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mynginx
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: mynginx
    spec:
      containers:
      - image: nginx
        name: nginx
        resources: {}
status: {}

然后执行命令:

#执行
kubectl apply -f mynginx.yaml

#查看
kubectl get deploy -n dev --show-labels

4、Label选择器使用

在kubernetes中,Pod是最小的控制单元,但是kubernetes很少直接控制Pod,一般都是通过Pod控制器来完成的。Pod控制器用于pod的管理,确保pod资源符合预期的状态,当pod的资源出现故障时,会尝试进行重启或重建pod。

在kubernetes中Pod控制器的种类有很多,本章节只介绍一种:Deployment。

Deployment控制器就是通过标签选择器控制Pod的

 从上图可以看出,deployment控制器通过匹配标签  env=dev 来控制 Pod

我们现在通过yaml创建deployment资源,并且控制pod副本也有3个

然后,将其中一个pod的标签 env=dev 删除,看看什么效果

yaml:

apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: mynginx
  name: mynginx
  namespace: dev
spec:
  #控制pod 副本数量为3个
  replicas: 3
  selector:
    #deplyment通过标签选择器,控制拥有此标签的pod
    matchLabels:
      app: mynginx
      env: dev
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: mynginx
        env: dev
    spec:
      containers:
      - image: nginx
        name: nginx
        resources: {}
status: {}

执行后效果

然后这个时候删除 其中一个 pod,看看效果(deployment控制3个副本,这个时候我删除1个,那deployment会自动再创建一个) 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全栈行动派

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值