k8s 标签和选择器

  • 标签

标签是附体在k8s 资源对象的一组键值对,其存在的意义是按照用户的意图来组织资源,同时不对资源的核心逻辑产生影响。

yaml 复制代码
metadata: 
  labels:   
	key1: value1   
	key2: value2

标签名:

○ 标签名部分是必须的。

○ 不能多余 63 个字符。

○ 必须由字母、数字开始和结尾。

○ 可以包含字母、数字、减号(-)、下划线(_)、小数点(.)。

标签的 value :

○ 不能多于 63 个字符。

○ 可以为空字符串。

○ 如果不为空,则必须由字母、数字开始和结尾。

○ 如果不为空,可以包含字母、数字、减号(-)、下划线(_)、小数点(.)。

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: nginx-pod
  labels: # 标签
    app: nginx
    environment: prod 
spec:
  containers:
  - name: nginx
    image: nginx

pod 中标签的操作

  1. 添加标签

kubectl label pod nginx-pod hello=world

  1. 更新标签

kubectl label pod nginx-pod hello=java --overwrite

  1. 删除标签

kubectl label pod nginx-pod hello-

node 中标签的操作

  1. 添加标签

kubectl label node k8s-node1 node-role=ingress

  1. 更新标签

kubectl label node k8s-node1 node-role=ingress2 --overwrite

  1. 删除标签

kubectl label node k8s-node1 node-role-

  • 标签选择器

● 通常来讲,会有多个 Kubernetes 对象包含相同的标签。通过使用标签选择器(label selector),用户/客户端可以选择一组对象。标签选择器是 Kubernetes 中最主要的分类和筛选手段。

● Kubernetes 的 api-server 支持两种形式的标签选择器,equality-based 基于等式的 和 set-based 基于集合的 。标签选择器可以包含多个条件,并使用逗号进行分隔,此时只要满足所有条件的 Kubernetes对象才会被选中。

● 基于等式的标签选择器,可以使用三种操作符 = 、== 、!=。前两个操作符含义是一样的,都代表相等;后一个操作符代表不相等。

复制代码
# 选择了标签名为 `environment` 且 标签值为 `production` 的Kubernetes对象
kubectl get pods -l environment=production,tier=frontend

# 选择了标签名为 `tier` 且标签值不等于 `frontend` 的对象,以及不包含标签 `tier` 的对象
kubectl get pods -l tier != frontend

# 选择所有包含 `partition` 标签的对象
kubectl get pods -l partition

# 选择所有不包含 `partition` 标签的对象
kubectl get pods -l !partition

基于集合标签选择器,可以根据标签名的一组值进行筛选。支持的操作符有三种:in、notin、exists。

复制代码
# 选择所有的包含 `environment` 标签且值为 `production` 或 `qa` 的对象
kubectl get pods -l environment in (production, qa)

# 选择所有的 `tier` 标签不为 `frontend` 和 `backend`的对象,或不含 `tier` 标签的对象
kubectl get pods -l tier notin (frontend, backend)

# 选择包含 `partition` 标签(不检查标签值)且 `environment` 不是 `qa` 的对象
kubectl get pods -l partition,environment notin (qa)
相关推荐
Britz_Kevin5 小时前
从零开始的云计算生活——第四十六天,铁杵成针,kubernetes模块之Configmap资源与Secret资源对象
kubernetes·云计算·生活
北i5 小时前
ZooKeeper 一致性模型解析:线性一致性与顺序一致性的平衡
分布式·zookeeper·云原生
Britz_Kevin5 小时前
从零开始的云计算生活——第四十七天,细水长流,kubernetes模块之ingress资源对象
kubernetes·云计算·生活
进击的阿尔法猿7 小时前
docker
运维·docker·容器
iceland98 小时前
kubeadm方式部署k8s集群
云原生·容器·kubernetes
wdxylb13 小时前
云原生俱乐部-shell知识点归纳(1)
linux·云原生
木易双人青14 小时前
01-Docker-简介、安装与使用
运维·docker·容器
晴天彩虹雨18 小时前
存算分离与云原生:数据平台的新基石
大数据·hadoop·云原生·spark
罗不俷19 小时前
【RH134知识点问答题】第13章:运行容器
容器·rhel
春人.1 天前
PortainerCE 跨云管理:cpolar 内网穿透服务实现多环境统一控制
云原生·eureka