CNCF x Alibaba云原生技术公开课 第四章 理解 Pod 和容器设计模式
创始人
2024-05-31 02:23:52
0

1、Pod的实现原理

共享网络

  • Infra container:一个非常小的镜像,大概 100~200KB 左右,是一个汇编语言写的、永远处于“暂停”状态的容器。由于有了这样一个 Infra container 之后,其他所有容器都会通过 Join Namespace 的方式加入到 Infra container 的 Network Namespace 中。
  • 一个 Pod 里面的所有容器,它们看到的网络视图是完全一样的。即:它们看到的网络设备、IP地址、Mac地址等等,跟网络相关的信息,其实全是一份,这一份都来自于 Pod 第一次创建的这个 Infra container。
  • 整个 Pod 里面,Infra container 第一个启动。并且整个 Pod 的生命周期是等同于 Infra container 的生命周期的,与容器 A 和 B 是无关的。(结果:允许去单独更新 Pod 里的某一个镜像的,即:做这个操作,整个 Pod 不会重建,也不会重启。)

在这里插入图片描述

2、容器设计模式

案例

  • 需求:java写的war包+tomcat
    • 方案1:war和tomcat打包到一个镜像里,更新war和tomcat大批需要重做镜像
    • 方案2:war通过数据卷挂载到tomcat里面。(分布式存储系统:容器第一次运行在宿主机A,第二次运行在宿主机B,这两个地方都要能访问到war)
    • 方案3:利用init container,把 WAR 包从镜像里拷贝到一个 Volume 里面,然后启动容器去挂载Volume

Sidecar

  • 概念:在 Pod 里面,可以定义一些专门的容器,来执行主业务容器所需要的一些辅助工作
  • 应用
    • 原本需要在容器里面执行 SSH 需要干的一些事情,可以写脚本、一些前置的条件,其实都可以通过像 Init Container 或者另外像 Sidecar 的方式去解决;
    • 当然还有一个典型例子是日志收集(fluentd),日志收集本身是一个进程,是一个小容器,那么就可以把它打包进 Pod 里面去做这个收集工作; (业务容器将日志写在一个 Volume 里面,而由于 Volume 在 Pod 里面是被共享的,所以日志容器 —— 即 Sidecar 容器一定可以通过共享该 Volume,直接把日志文件读出来,然后存到远程存储)
    • Debug 应用,实际上现在 Debug 整个应用都可以在应用 Pod 里面再次定义一个额外的小的 Container,它可以去 exec 应用 pod 的 namespace;
    • 查看其他容器的工作状态,实现应用监控。不再需要去 SSH 登陆到容器里去看,只要把监控组件装到额外的小容器里面就可以了,然后把它作为一个 Sidecar 启动起来,跟主业务容器进行协作,所以同样业务监控也都可以通过 Sidecar 方式来去做。
    • 代理容器:单独写一个这么小的 Proxy,用来处理对接外部的服务集群,它对外暴露出来只有一个 IP 地址就可以了。所以接下来,业务容器主要访问 Proxy(localhost通信,性能损耗忽略),然后由 Proxy 去连接这些服务集群。
    • 适配器容器:将业务容器暴露出来的接口转换成另一种格式。举例:业务容器暴露出来的监控接口是 /metrics,访问这个这个容器的 metrics 的这个 URL 就可以获取信息。可是后来这个监控系统升级了,它访问的 URL 是 /health,只认得暴露出 health 健康检查的 URL,才能去做监控,metrics 不认识。如果不改代码,可以额外写一个 Adapter,用来把所有对 health 的这个请求转发给 metrics 就可以了,所以这个 Adapter 对外暴露的是 health 监控的 URL。
  • 优势:通过sidecar,将辅助功能和业务容器解耦;解耦之后则可复用
    • 设计模式的本质:解耦和重用

RPC
remote procedure call:远程过程调用,一个节点请求另一个节点提供的服务

相关内容

热门资讯

kindle安装安卓系统费电,... 亲爱的Kindle迷们,你们是不是也和我一样,对自家的Kindle刷上安卓系统充满了好奇和期待呢?不...
ios系统还是安卓系统好用,揭... 说到手机系统,你是不是也和我一样,每次逛手机店都纠结得要命?iOS和安卓,哪个才是你的菜?今天,我就...
外卖快送安卓系统,打造智慧生活... 你知道吗?最近手机界可是炸开了锅,一款全新的安卓系统横空出世,它不仅让外卖快送变得更快更智能,还让我...
安卓p系统发布时间,揭秘安卓9... 你知道吗?最近安卓P系统终于发布了,这可是科技圈的大事啊!作为一个紧跟潮流的数码爱好者,我可是迫不及...
酷开系统能用安卓系统吗,智能电... 你有没有想过,家里的智能电视是不是也能像手机一样,装上各种好玩的应用呢?今天,咱们就来聊聊这个话题—...
安卓系统滴滴打车页面,便捷出行... 你有没有发现,每次打开手机上的滴滴打车APP,那个安卓系统的页面简直就像是个移动的指挥中心,信息丰富...
稳定系统版本安卓软件,软件版本... 哎呀呀,亲爱的手机控们,你们有没有遇到过这样的烦恼:手机里下载了好多软件,可就是有些软件总是不稳定,...
基于安卓的投票系统,基于安卓平... 投票新时代,指尖上的民主盛宴 在这个信息爆炸的时代,手机已经成为了我们生活中不可或缺的伙伴。而今天,...
怎么把安卓系统换掉,教你如何将... 你有没有想过,你的安卓手机是不是有点儿“老态龙钟”了呢?想要给它来个“换头术”,让它焕发青春活力?那...
安卓系统笔记平板推荐,高效办公... 你有没有想过,拥有一款性能卓越、功能丰富的安卓系统笔记平板,简直就是工作和学习的好帮手呢?想象你可以...
安卓系统如何隐藏图片,隐私保护... 你是不是也有那么几张不想让别人看到的照片呢?别担心,今天就来教你怎么在安卓系统里巧妙地隐藏它们,让它...
ios手机装安卓系统,探索安卓... 你有没有想过,如果你的iPhone突然变成了安卓手机,那会是怎样的场景呢?想象你那熟悉的iOS界面,...
苹果刷成了安卓系统,跨平台体验... 你知道吗?最近有个大新闻在科技圈里炸开了锅,那就是有人竟然把苹果手机刷成了安卓系统!这可不是闹着玩的...
小米4安卓系统版本,从安卓4.... 你有没有想过,你的小米4手机里藏着一个小秘密?那就是它正在运行的安卓系统版本。今天,就让我带你一探究...
鸿蒙系统删除安卓应用,迈向纯净... 亲爱的手机控们,你们有没有想过,你的手机里那些占地方又用不着的安卓应用,其实是可以说拜拜的?没错,我...
安卓系统哪个可以听歌,探索最佳... 你有没有想过,手机里那么多应用,哪个才是最适合你的听歌神器呢?安卓系统里,听歌的选择可真是五花八门,...
君威升级安卓系统,安卓系统助力... 哇塞,你有没有想过,你的君威车机系统也能来个华丽变身?没错,就是升级安卓系统!想象在驾驶的过程中,一...
五太子安卓6.0系统,深度解析... 亲爱的读者们,今天我要给大家带来一款特别有趣的手机系统——五太子安卓6.0系统。这款系统可是有着不少...
安卓系统性能损耗,原因、影响与... 你有没有发现,你的安卓手机好像越来越慢了?是不是觉得它就像一个老态龙钟的老年人,虽然曾经年轻力壮,但...
安卓 系统软件删除,轻松管理手... 手机里的应用是不是越来越多,感觉就像是个小型的超市,琳琅满目的商品让人挑花了眼?但你知道吗,有些应用...