【Kubernetes知识点问答题】Namespace(命名空间)

目录

[1. 什么是 K8s 的 namespace?](#1. 什么是 K8s 的 namespace?)

[2. 系统默认创建了哪几个 namespace?](#2. 系统默认创建了哪几个 namespace?)

总结


在 Kubernetes(K8s)中,随着集群规模的扩大和用户数量的增加,如何高效、灵活地管理资源成为一个重要的课题。为了在同一个集群中实现资源的隔离和组织,Kubernetes 引入了 Namespace(命名空间) 这一概念。

1. 什么是 K8s namespace

Kubernetes 中的 Namespace 是一种资源隔离机制,它将同一个集群中的资源划分为不同的组,允许多个用户或项目在同一个 Kubernetes 集群中并行运行,而不会相互干扰。每个 Namespace 都是独立的,其资源管理、配额、网络策略等都是相互隔离的。通过 Namespace,可以提高集群资源的使用效率,避免资源冲突,保证系统的安全性和稳定性。

Namespace 的作用仅限于那些带有命名空间的对象。例如:

  • Deployment:可以在不同的 Namespace 中创建同名的 Deployment。

  • Service:每个命名空间内的服务是相互隔离的。

但是,命名空间不适用于集群范围的资源。例如:

  • StorageClass:这是一个集群级别的对象,在不同命名空间中是共享的。

  • Node:节点是整个集群的资源,和命名空间无关。

  • PersistentVolume (PV):也不属于任何命名空间,而是集群级别的资源。

2. 系统默认创建了哪几个 namespace

default:用户创建资源对象时的默认命名空间。大多数情况下,用户的资源都会放在这个命名空间下。

kube-node-lease:包含用于与各个节点关联的 lease(租约)对象,lease 保证 kubelet 可 以向 api-server 发送心跳,以确保控制面能够检测到节点的健康状况。以便控制面能够检测到节点故障。

kube-public:所有的客户端(包括未经身份验证的客户端)都可以读取该命名空间。通常,系统级的公共资源(如集群的公共配置或文档)会放在这个命名空间中。

kube-system:该命名空间用于 Kubernetes 系统创建的对象。这里的资源通常由 K8s 自己管理,比如控制面组件(如 kube-apiserver, kube-scheduler)和一些集群管理工具(如 DNS、网络插件等)。这些资源是集群正常运行所必需的。

总结

Kubernetes 的 Namespace 是一种强大的机制,可以帮助我们在集群中进行资源的隔离和管理。通过合理的命名空间设计,开发团队可以在同一个集群内创建多个独立的工作环境,防止资源冲突,并提高集群的可管理性。

相关推荐
没有bug.的程序员3 小时前
500个微服务上云全线假死:Spring Boot 3.2 自动配置底层的生死狙击
java·spring boot·微服务·kubernetes·自动配置
SelectDB技术团队4 小时前
OLAP 无需事务?Apache Doris 如何让实时分析兼具事务保障
数据库·数据仓库·人工智能·云原生·实时分析
renhongxia14 小时前
人工智能代理能生成微服务吗?我们离多远了?
人工智能·深度学习·学习·微服务·云原生·架构·机器人
2501_941149504 小时前
2026 级微服务演进:深度解析 Cosvice 架构下的服务编排与性能调优
微服务·云原生·架构
小龙加油!!!5 小时前
k8s 部署中间件(mysql、redis、minio、nacos)并持久化数据
mysql·中间件·kubernetes
宋明河5 小时前
写了一个小工具,在Get k8s 资源的yaml只看自己改过的配置参数,过滤默认的以及附加的参数
云原生·容器·kubernetes
切糕师学AI6 小时前
K8s 中,为什么同一主机上的两个 Pod 可以监听相同端口而不冲突?
云原生·容器·kubernetes
不光头强6 小时前
k8s知识点
云原生·容器·kubernetes
徒 花6 小时前
Docker在Ubuntu上的安装及配置(基于k8s基础环境配置)
ubuntu·docker·kubernetes