k8s中Label概念及常用操作

什么是Label

Label(标签):
Lable是一个key-value键值对,由用户自己制定。可以附加在各种资源上,比如node 、 pod、 svc、 rc等,一个对象资源可以定义任意数量的Lable,同时一个lable也可以被添加到任意数量的资源对象上去, Lable可以在资源对象定义时确定,也可以在对象创建后动态添加和删除。
我们可以使用指定的资源对象绑定一个或者多个不同的lable来实现多维度的资源分组管理功能,以便于灵活、方便的对资源进行分配、调度、配置、部署等工作。
Lable就是给资源对象打一个标签,然后通过Label Secletor(标签选择器)查询和筛选拥有某些Label的资源对象,k8s通过这种方式实现了类似SQL的简单和通用的对象查询机制。


查看资源的labels(标签)

# 查看pod的标签
kubectl get pods --show-labels

# 查看指定serice选择的标签
kubectl get service tomcatdemo --show-labels

# 通过yaml方式查看service选择的标签
[root@master ~]# kubectl get service tomcatdemo -o yaml|grep -A 2 selector
  selector:
    app: tomcatdemo
  sessionAffinity: None

组合标签查询语法

标签选择器可以类比SQL语句中的where查询条件,例如:

name=redis-salve 	# 表示只查询名字为redis-salve的资源对象。

env != production	# 匹配所有不具有标签 env = production 的资源对象

name in( redis-master, redis-salve)# 匹配所有带有标签name=master或者name=salve的资源

name not in ( php)#匹配所有不具有标签name=php的资源对象

也可以多个条件一起使用。
标签和标签选择器共同构成了k8s系统中最核心的应用模型, 使得被管理对象能够被精细的分组管理,同时实现了整个集群的高可用性。


指定标签查询资源

# 指定标签查询pod
## 查询ns=kube-system 标签: k8s-app=kube-dns的pod
kubectl get po -n kube-system -l k8s-app=kube-dns
## 同时显示资源的标签信息
kubectl get po -n kube-system -l k8s-app=kube-dns --show-labels

根据label删除资源

# 删除包含 name=myLabel 标签的 pods 和服务
kubectl delete pods,services -l name=myLabel

# 删除所有包含某个标签的pod和service
kubectl delete pods,services –l name=<label-name>

给node打标签

kubectl label nodes <node_name> key1=val1 key2=val2

删除node的标签

kubectl label nodes <node_name> key1- key2-

查询node节点已有的标签:

kubectl get node --show-labels=true

将pod调度到指定node上

将pod调度到带有指定标签的node上

apiVersion: extensions/v1
kind: Deployment
metadata:
  name: nginx
spec:
  replicas: 1
  template:
    metadata:
      labels:
        app: nginx
    spec:
    # 选择标签
      nodeSelector:
        key1: val1
        key2: val2
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

猜你喜欢

转载自blog.csdn.net/omaidb/article/details/122727166