• K8s Docker实践二


    在上文 K8s Docker实践一 中我们已经基于K8s实现了最简部署,下面我们对K8s进行深入学习。

    云原生-k8s核心概念

    • namespace
      Namespace是kubernetes系统中的一种非常重要资源,它的主要作用是用来实现多套环境的资源隔离或者多租户的资源隔离

    • Pod
      Pod可以认为是容器的封装,一个Pod中可以存在一个或者多个容器。Pod是k8s中最小的可部署单元。

    • Deployment
      kubernetes很少直接控制Pod,一般都是通过Pod控制器来完成的。Pod控制器用于pod的管理,确保pod资源符合预期的状态,当pod的资源出现故障时,会尝试进行重启或重建pod。

    • Service
      Service可以看作是一组同类Pod对外的访问接口。借助Service,应用可以方便地实现服务发现和负载均衡。

    基础操作

    namespace

    默认情况下,kubernetes集群中的所有的Pod都是可以相互访问的。但是在实际中,可能不想让两个Pod之间进行互相的访问,那此时就可以将两个Pod划分到不同的namespace下。

    kubernetes通过将集群内部的资源分配到不同的Namespace中,可以形成逻辑上的"组",以方便不同的组的资源进行隔离使用和管理。

    可以通过kubernetes的授权机制,将不同的namespace交给不同租户进行管理,这样就实现了多租户的资源隔离。此时还能结合kubernetes的资源配额机制,限定不同租户能占用的资源,例如CPU使用量、内存使用量等等,来实现租户可用资源的管理。

    kubernetes在集群启动之后,会默认创建4个namespace:

    # kubectl  get namespace
    
    NAME              STATUS   AGE
    default           Active   45h     #  所有未指定Namespace的对象(容器)都会被分配在default命名空间
    kube-node-lease   Active   45h     #  集群节点之间的心跳维护,v1.13开始引入
    kube-public       Active   45h     #  此命名空间下的资源可以被所有人访问(包括未认证用户)
    kube-system       Active   45h     #  所有由Kubernetes系统创建的资源都处于这个命名空间
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    下面来看namespace资源(简写ns)的具体操作:

    参考:
    https://blog.csdn.net/weixin_48751167/article/details/123507306

  • 相关阅读:
    微信小程序实战十四:小程序及APP端实现客服功能
    Flink / Scala - Metrics 使用与详解
    Redis(三)
    【react-native】关于ios与android的环境搭建
    SQLite 3.44.0 发布!
    接口测试CURL复制以及postman的Code功能
    SH-SSS丨《ISSD: 基于迭代式语音分离的说话人日志系统》论文线上分享
    python模块之redisbloom redis布隆过滤器
    领域驱动设计DDD:贫血模型和充血模型(比较重要)
    算法-- 爬楼梯(Kotlin)
  • 原文地址:https://blog.csdn.net/qq_15437629/article/details/134472763