当前位置:   article > 正文

k8s中Label概念及常用操作_kubectl label nodes

kubectl label nodes

什么是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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

组合标签查询语法

标签选择器可以类比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的资源对象
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

也可以多个条件一起使用。
标签和标签选择器共同构成了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
  • 1
  • 2
  • 3
  • 4
  • 5

根据label删除资源

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

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

给node打标签

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

删除node的标签

kubectl label nodes <node_name> key1- key2-
  • 1

查询node节点已有的标签:

kubectl get node --show-labels=true
  • 1

将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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/578866
推荐阅读
  

闽ICP备14008679号