【云原生 • Kubernetes】kubernetes 核心技术 - Label 和 Selector

发布于:2023-01-14 ⋅ 阅读:(161) ⋅ 点赞:(0)

在这里插入图片描述


当 Kubernetes 对系统中任何 API 对象(如 Pod 和节点)进行 “分组” 时,会为其添加 Label(键值对格式 key=value)用以精准的选择对应的 API 对象。而 Selector 则是针对匹配对象的查询方法。总结起来二者的分工就是:

  • Label 用于给某个资源定义标识
  • Label Selector 用于查询和筛选拥有某些标签的资源对象

1. Label 概述

Label(标签) 是 Kubernetes 的一个核心概念。一个 Label 就是一个 key:value 的键值对被关联到对象上,其中 key 与 value 由用户自己指定。

"labels": {
  "key1" : "value1",
  "key2" : "value2"
}

标签的使用使得我们能标识出对象的一些特殊特点,比如说标识了某个 Pod,那么用户就可以一眼看出这个 Pod 是干什么的。

标签可以用来划分特定组的对象,可以在创建一个对象的时候直接给与,也可以在后期动态添加或删除,每一个对象可以拥有多个标签,但是 key 值必须是唯一的。Label 也可以附加到各种资源对象上,如 Node、Pod、Service、RC,一个资源对象可以定义任意数量的 Label,同一个 Label 也可以被添加到任意数量的资源对象上。

在这里插入图片描述

2. Label 语法规则

语法格式:key: value(键值对)

Key:

  • 不超过 63 个字符
  • 支持使用前缀,前缀必须是 DNS 子域,不超过253个字符。
  • 系统化组件创建的 label 必须指定前缀。kubernetes.io 和 k8s.io 由 kubernetes 保留
  • 格式:[A-Za-z0-9][A-Za-z0-9_-.]

value:

  • 不超过 63 个字符
  • 格式:[A-Za-z0-9][A-Za-z0-9_-.]

3. Label 的定义

Label 最常见的用法是使用 metadata.labels 字段来为对象定义 Label,使用 spec.selector 字段来引用对象。如下:

#添加Label
apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
	app: new_nginx #定义Label:new_nginx
#引用label
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  replicas: 1
  selector:
	app: new_nginx #引用刚刚定义的Label:new_nginx

Label 附加到 Kubernetes 集群中的各种资源对象上,目的就是对这些资源对象进行分组管理,而分组管理的核心正是 Label Selector。需要知道 Label 与 Label Selector 都不能单独定义,必须附加在一些资源对象的定义文件上,一般是附加在 RC 和 Service 的资源定义文件中的。

4. Label 常用命令

  • 查看标签
kubectl get pod nginx -n dev --show-labels
  • 为 Pod 资源打标签
#为名为nginx的pod添加label aaa=bbb
kubectl label pod nginx aaa=bbb -n dev
  • 为 Pod 资源更新标签
#将名为nginx的pod的label修改为ccc=ddd,且覆盖现有的value
kubectl label pod nginx ccc=ddd -n dev --overwrite
  • 筛选标签
kubectl get pod -n dev -l eee=fff --show-labels
  • 删除标签
#删除nginx中名为aaa的label
kubectl label pod nginx aaa- -n dev

本章学习目标:

  • 掌握 Kubernetes 中 Label 和 Selector 的相关概念与使用方法。
本文含有隐藏内容,请 开通VIP 后查看