kubernetes基础知识


个人博客文章链接:kubernetes基础知识 - masaka的树屋 欢迎关注

核心概念

container

docker等容器,提供docker镜像运行的环境。docker利用namespace、cgroup等linux提供的能力,来使运行在同一机器上的各个container互不影响。各container都认为自己拥有独立的文件、进程等系统,同时,机器的cpu、内存等资源也被划分给不同的container。

pods

一个container正常来说只应该包含一个进程,因为这样能更好的监控container的状态,可以理解为k8s监控的最小粒度就是container;而一个pod会包含一个或多个紧密相关的container,一个pod下的container会部署在一个物理节点,也就意味着一个pod下不同container的交互是可以通过localhost进行的。

一般来说,一个pod中只会有一个container,存在多个container的情况一般是一个为主container,其他container负责辅助做一些事情,比如说log agent负责上报主container生产的日志。

labels

所有k8s的资源,比如pod、node,都可以被打上标,label为kv形式,且一个资源上能打上多种标签。打完标签后,可以通过label selectors来筛选出打上特定label的资源。

比方说可以将不同版本的pod通过label打上不同的标签:version=v1/v2/…,然后利用label selectors就可以将version=v1的pod全部取出。label还可以标示node资源,举个例子:如果某些node底层是gpu,可以将这些nodes搭上label:gpu=true,然后在部署需要在gpu上运行的服务时,便可通过label selectors来指定特定的pods需要部署在gpu=true的nodes上。

namespace

一个pod可能会有多个label,但只会有一个namespace。namespace的概念可以类比于租户,通过namespace可以指定到不同的租户的命名空间。但需要注意的是,namespace仅仅是个逻辑上的分类,在你指定了某个namespace后,你只能看到对应namespace的pod,但并不作其他方面的区分,比方说不同namespace的pod仍可以互相调用

replication

replicationController

监控正在运行的pods,并确保pods的数量是和配置好的数量是一样的。replicationController通过label selector来指明需要关注的pods,如果某个pod在运行期间修改了label,导致特定的replicationController通过label selector找不到该pod了,那么replicationController会根据配置重新建立pod

replicaSets

用来替代replicationController࿰

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值