命名空间
命名空间(namespace)是一种在多个用户之间划分资源的方法。适用于用户中存在多个团队或项目的情况。
当前云容器实例提供“通用计算型”资源,创建命名空间时需要选择资源类型,后续创建的负载中容器就运行在此类型的集群上。
- 通用计算型:支持创建含CPU资源的容器实例,适用于通用计算场景。
- 一个账号在一个区域,目前只能使用5个命名空间。
- 通用计算型支持X86镜像。
命名空间与网络的关系
从网络角度,命名空间对应一个虚拟私有云(VPC)中一个子网,如图1所示,在创建命名空间时会关联已有VPC或创建一个新的VPC,并在VPC下创建一个子网。后续在该命名空间下创建的容器及其他资源都会在对应的VPC及子网之内。
通常情况下,如果您在同一个VPC下还会使用其他服务的资源,您需要考虑您的网络规划,如子网网段划分、IP数量规划等,确保有可用的网络资源。
哪些情况下适合使用多个命名空间
因为namespace可以实现部分的环境隔离。当你的项目和人员众多的时候可以考虑根据项目属性,例如生产、测试、开发划分不同的namespace。
创建命名空间
- 登录云容器实例管理控制台,左侧导航栏中选择“命名空间”。
- 在对应类型的命名空间下单击“创建”。
- 填写命名空间名称。
命名空间名称在云容器实例中需全局唯一。
- 设置RBAC权限。
开启RBAC鉴权后,用户使用命名空间下的资源将受到RBAC权限控制,详情请参见命名空间权限。
- 选择企业项目。CCI中每个命名空间对应一个企业项目,一个企业项目下可以有多个命名空间。
- 设置VPC。
选择使用已有VPC或新建VPC,新建VPC需要填写VPC网段,建议使用网段:10.0.0.0/8~22,172.16.0.0/12~22,192.168.0.0/16~22。
此处VPC和子网的网段不能为10.247.0.0/16,10.247.0.0/16是云容器实例预留给负载访问的网段。如果您使用此网段,后续可能会造成IP冲突,导致负载无法创建或服务不可用;如果您不需要通过负载访问,而是直接访问Pod,则可以使用此网段。
命名空间创建完成后,在“网络管理 > 容器网络”中可查看到VPC和子网信息。
- 设置子网网段。
您需要关注子网的可用IP数,确保有足够数量的可用IP,如果没有可用IP,则会导致负载创建失败。
图2 子网设置
- 创建的namespace会在设置的子网中预热部分IP,默认个数为10个。
- 在高级设置中可以设置预热的个数。
- 创建namespace后,由于预热了部分IP,会影响设置的subnet和VPC的删除,需要删除namespace之后才能正常删除对应的subnet和VPC。
- 高级设置。
每个命名空间下都提供了一个IP池,申请IP需要一段时间,如果需要快速创建负载,减少IP的申请时间,可通过自定义资源池大小来实现。
例如,某业务线日常的负载数为200,当达到流量高峰时,IP资源池会自动扩容,瞬间将IP资源池扩容到500(IP资源池大小),同时会在回收间隔23h(IP资源池回收间隔)之后,进行回收超过资源池大小的部分即(500-200)个。
图3 高级设置
- 预热IP资源池大小(个):为每个命名空间预热一个IP池,用来加速负载创建。预热IP资源池的大小不能超过500个。
- 预热IP资源池回收间隔(h):IP资源池弹性扩容出来的空闲IP资源, 在一定时间内可进行回收。
- 容器网络预准备:容器启动时,可能会没有网络连接。如果容器在启动时,需要立即连接网络, 可开启此处的“容器网络预准备”开关。
- 单击“创建”。
创建完成后,可以在命名空间详情中看到VPC、子网等信息。
删除命名空间
删除命名空间将会删除该命名空间相关的所有数据资源(工作负载、ConfigMap、Secret、SSL证书等)。
- 登录云容器实例管理控制台,左侧导航栏中选择“命名空间”,单击要删除的命名空间,进入命名空间详情页面。
- 单击右上角“删除”,并输入DELETE,然后单击“确认”。
如需删除VPC、Subnet请前往虚拟私有云。
使用kubectl创建命名空间
使用kubectl创建命名空间请参见Namespace和Network。