kubernetes-handbook/concepts/namespace.md

1.4 KiB
Raw Blame History

Namespace

在一个Kubernetes集群中可以使用namespace创建多个“虚拟集群”这些namespace之间可以完全隔离也可以通过通过某种方式让一个namespace中的service可以访问到其他的namespace中的服务我们在CentOS中部署kubernetes1.6集群的时候就用到了好几个跨越namespace的服务比如Traefik ingress和kube-systemnamespace下的service就可以为整个集群提供服务这些都需要通过RBAC定义集群级别的角色来实现。

哪些情况下适合使用多个namesapce

因为namespace可以提供独立的命名空间因此可以实现部分的环境隔离。当你的项目和人员众多的时候可以考虑根据项目属性例如生产、测试、开发划分不同的namespace。

Namespace使用

获取集群中有哪些namespace

kubectl get ns

集群中默认会有defaultkube-system这两个namespace。

在执行kubectl命令时可以使用-n指定操作的namespace。

用户的普通应用默认是在default下,与集群管理相关的为整个集群提供服务的应用一般部署在kube-system的namespace下例如我们在安装kubernetes集群时部署的kubednsheapseterEFK等都是在这个namespace下面。

另外并不是所有的资源对象都会对应namespacenodepersistentVolume就不属于任何namespace。