当前位置: 首页 > article >正文

K8S之Namespace的介绍和使用

Namespace的理论和实操

  • Namespace理论说明
  • Namespace实操
    • 创建、查看命名空间
    • 使用ResouceQuota 对Namespace做资源限额
      • 更多ResouceQuota 的使用

Namespace理论说明

命名空间定义
K8s支持多个虚拟集群,它们底层依赖于同一个物理集群。 这些虚拟集群被称为命名空间(Namespace)。

Namespace应用场景
Namespace是k8s集群级别的资源,可以给不同的用户、租户、环境或项目创建对应的命名空间。
例如,可以为devlopment、test、production环境分别创建各自的命名空间。

Namespace实操

创建、查看命名空间

创建一个Namespace为test

kubectl create ns test

查看Namespace

kubectl get ns

在这里插入图片描述

使用ResouceQuota 对Namespace做资源限额

在K8s集群中通过 ResouceQuota 对象定义每个Namespace的资源配额,从而实现资源消耗总量的限制。
ResouceQuota 有两个作用:

  • 可以按类型限制Namespace下所创建对象的数量
  • 限制所消耗计算资源的总量

示例说明:
创建ResouceQuota 对象,对 test 命名空间中添加以下限制:
只能建4个pod、每个容器必须设置内存请求、内存限额、cpu请求和cpu限额。
步骤:
1、创建ResouceQuota 对象
编写ResouceQuota 资源文件

vim namespace-quota.yaml
apiVersion: v1
kind: ResourceQuota
metadata:
  name: mem-cpu-quota
  namespace: test  # 指定限制的命名空间名称
spec:
  hard:
    pods: "4"    
    requests.cpu: "2"    # 所有容器的CPU请求总额不得超过2 CPU
    requests.memory: 2Gi # 所有容器的内存请求总额不得超过2GiB
    limits.cpu: "4"      # 所有容器的CPU限额总额不得超过4CPU
    limits.memory: 4Gi   # 所有容器的内存限额总额不得超过4 GiB

创建ResouceQuota

kubectl apply -f namespace-quota.yaml

ResouceQuota 对象是在Namespace为test中创建的,并准备好控制该名称空间中的所有容器的总请求和限制。

kubectl get resourcequota -n test

在这里插入图片描述

2、创建Pod 对象

创建Pod 时候必须设置资源限额,否则创建失败

编写Pod 资源文件

vim pod-test.yaml
apiVersion: v1
kind: Pod
metadata:
  name: pod-test
  namespace: test
  labels:
    app: tomcat-pod-test
spec:
  containers:
  - name:  tomcat-test
    image: tomcat-8.5-jre8:v1
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 8080
    resources:
      requests:
        memory: "100Mi"
        cpu: "500m"
      limits:
        memory: "2Gi"
        cpu: "2"

创建Pod

kubectl apply -f pod-test.yaml

再看命名空间下的资源

kubectl get resourcequota -n test

在这里插入图片描述

更多ResouceQuota 的使用

官网文档:https://kubernetes.io/zh-cn/docs/concepts/policy/resource-quotas/


http://www.kler.cn/a/228749.html

相关文章:

  • elasticsearch基础
  • KubeSphere部署安装,接入KubeKey安装的k8s集群
  • Amazon MSK 开启 Public 访问 SASL 配置的方法
  • 2024年博客之星年度评选—创作影响力评审入围名单公布
  • 深度学习 Pytorch 基本优化思想与最小二乘法
  • (十五)WebGL中gl.texImage2D函数使用详解
  • ubuntu离线安装k8s
  • Python中的while循环,知其然知其所以然
  • ###C语言程序设计-----C语言学习(9)#函数基础
  • 【实战系列----消息队列 数据缓存】rabbitmq 消息队列 搭建和应用
  • C语言第十八弹---指针(二)
  • windows10忘记密码的解决方案
  • 前端JavaScript篇之JavaScript为什么要进行变量提升,它导致了什么问题?什么是尾调用,使用尾调用有什么好处?
  • protoc结合go完成protocol buffers协议的序列化与反序列化
  • BFS——双向广搜+A—star
  • 阿里云计算巢是什么?计算巢服务详细介绍
  • 无锁序列系列笔记
  • 使用MySQL Workbench连接MySQL很慢
  • vue2.0+使用md-edit编辑器
  • Android学习之路(29) Gradle初探
  • Django学习记录02
  • Camera2+OpenGL ES+MediaCodec+AudioRecord实现录制音视频写入H264 SEI数据
  • 大数据信用报告查询费用一般要多少钱?
  • 设置 相关
  • 共享网盘系统PHP源码
  • 两次NAT