赞
踩
Label(标签):
Lable是一个key-value键值对,由用户自己制定。可以附加在各种资源上,比如node 、 pod、 svc、 rc等,一个对象资源可以定义任意数量的Lable,同时一个lable也可以被添加到任意数量的资源对象上去, Lable可以在资源对象定义时确定,也可以在对象创建后动态添加和删除。
我们可以使用指定的资源对象绑定一个或者多个不同的lable来实现多维度的资源分组管理功能,以便于灵活、方便的对资源进行分配、调度、配置、部署等工作。
Lable就是给资源对象打一个标签,然后通过Label Secletor(标签选择器)查询和筛选拥有某些Label的资源对象,k8s通过这种方式实现了类似SQL的简单和通用的对象查询机制。
# 查看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
# 删除包含 name=myLabel 标签的 pods 和服务
kubectl delete pods,services -l name=myLabel
# 删除所有包含某个标签的pod和service
kubectl delete pods,services –l name=<label-name>
kubectl label nodes <node_name> key1=val1 key2=val2
kubectl label nodes <node_name> key1- key2-
kubectl get node --show-labels=true
将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
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。