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