命名空间和标签
命名空间
命名空间是一种用于在Kubernetes集群中划分资源的虚拟化手段。每个资源都属于一个命名空间,使得多个团队或应用可以在同一个集群中独立运行,避免资源冲突。
关键属性和配置选项
属性 | 描述 | 示例 |
---|---|---|
Namespace Name | 命名空间的唯一标识符 | my-namespace |
Status | 命名空间的状态,如 Active 或 Terminating | Active |
Phase | 命名空间的生命周期阶段 | Active, Terminating |
Labels | 命名空间的标签,用于组织和选择命名空间 | {"project": "my-project", "environment": "dev"} |
Annotations | 命名空间的注解,用于存储非标识性信息 | {"description": "Development environment for my project"} |
Resource Quotas | 命名空间的资源配额,限制命名空间内资源的使用量 | {"hard": {"pods": "10", "services": "5", "replicationcontrollers": "20"}} |
Limit Ranges | 命名空间的资源限制范围,为命名空间内的 Pod 设置资源请求和限制 | {"limits": [{"type": "Container", "defaultRequest": {"cpu": "100m", "memory": "200Mi"}}]} |
Network Policies | 命名空间的网络策略,定义 Pod 间的网络访问规则 | {"podSelector": {}, "ingress": [{"from": [{"podSelector": {}}]}]} |
命名空间的创建
- yaml文件方式
apiVersion: v1
kind: Namespace
metadata:
name: my-namespace
- 命令方式
kubectl create ns xxx
命名空间的使用
代码语言:javascript复制kubectl get namespaces
kubectl get pods -n my-namespace
默认命名空间
所有未明确指定命名空间的资源都属于默认命名空间。使用 -n 或 --namespace 选项可以指定操作的命名空间。
标签
标签是Kubernetes中用于对资源进行元数据标记的机制。标签是键值对,可以附加到Pod、Service、Node等各种资源上,以便于资源的分类、过滤和组织。
关键属性和配置选项
属性 | 描述 | 示例 |
---|---|---|
Key | 标签的键,用于标识资源的分类或属性 | "app", "environment", "tier" |
Value | 标签的值,与键一起定义资源的特征 | "my-app", "production", "frontend" |
Usage | 标签的使用场景,如选择器、组织资源等 | 用于选择特定应用的所有 Pod |
Syntax | 标签的语法规则,键和值的命名规范 | 键以字母或数字开头,可包含 -, _, . 等 |
Character Limit | 标签键和值的字符限制 | 键最多63个字符,值最多253个字符 |
Label Selectors | 通过标签选择资源的查询语法 | {matchLabels: {"app": "my-app"}, matchExpressions: [{key: "environment", operator: "In", values: ["production", "staging"]}} |
标签的添加
- yaml 中直接定义
metadata:
labels:
app: my-app
environment: production
- 命令行定义
kubectl label [--overwrite] key1=value1 key2
kubectl label pod pod-kubectl key1=value1 key2=2
// 如果更新label值,则需要带上--overwrite
kubectl label pod pod-kubectl --overwrite key1=value1 key2=2
//查看定义的标签
kubectl get pod -owide --show-labels
标签的查询
- 查询pod指定label
kubectl get pods -l app=my-app
kubectl get pods -l environment=production
- 多标签选择
kubectl get pods -l app=my-app,environment=production
- in /not in选择
kubectl get pod -l 'key2 in(3,4)'
kubectl get pod -l 'key2 notin(3)' --show-labels
- 应用选择器
selector:
matchLabels:
component: redis
matchExpressions:
- { key: tier, operator: In, values: [cache] }
- { key: environment, operator: NotIn, values: [dev] }
标签和命名空间的结合使用,使得Kubernetes集群能够更好地组织和管理各种资源。
标签可以帮助你根据不同的属性对资源进行分类,而命名空间则可以将资源分组到独立的隔离单元中。这种组织结构使得Kubernetes集群更加灵活和易于管理。