首页 > 运维 > linux运维 > 正文

虚拟化与云计算硬核技术内幕 (32) —— 产品经理与潘金莲

蓮花仙者
发布: 2025-07-15 10:14:44
原创
437人浏览过

在上一期中,小e学习了如何利用namespace机制,实现了进程之间cpu、ram、网络、用户、文件系统挂载点和进程ipc的隔离,同时也学习了利用cgroups机制,来限制进程对资源的使用,例如将进程占用的cpu时间片限制为100mcore (100毫核,相当于0.1核)。

有了这两种机制,是不是就可以在宿主机上运行轻量级虚拟化的进程了呢?

我们还需要解决一个问题——对宿主机的文件系统进行保护。

由于云平台上的宿主机,会提供给不同的租户用于运行自己的应用,因此有可能面临两个问题:

  1. 租户恶意篡改操作系统运行所需的文件;
  2. 如果租户的应用所依赖的glibc等运行时库版本,与操作系统自带的版本不符,需要更新操作系统带的这些库,如何避免这些更新与其他租户在宿主机上的依赖库冲突呢?

与方老师差不多年纪的读者可能记得,大学里的公共计算机教室,为了保护计算机系统不会被熊孩子们破坏,老师们在计算机上加了一块硬盘保护卡,使得对系统盘的任何写入,在计算机重启后,都会被还原。

(当然,硬盘保护卡是通过接管BIOS的INT13中断实现的,想了解这个机制可以关注我们以后的专题——软硬件融合)

在Linux下,也有类似“硬盘保护卡”的机制。这一机制叫做UnionFS。

UnionFS为操作系统下的不同进程提供了虚拟化的一个文件系统。这如何理解呢?

请看下图。

虚拟化与云计算硬核技术内幕 (32) —— 产品经理与潘金莲如图所示,宿主机上的CentOS有自身的一套操作系统文件(当然,也包括Linux下都有的ld-linux.so.2),而CentOS上运行的三个应用A,B和C,所依赖的ld-linux.so.2的版本有一定的差异。UnionFS能够为这三个不同的进程,提供各自虚拟化的文件系统,以及存放各自依赖的不同版本的ld-linux.so.2动态链接库。

在进程结束后,UnionFS为这些进程提供的虚拟文件系统也将被销毁,因此,进程对自己虚拟化的文件系统的修改,对宿主机不造成任何影响。

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

阿里云-虚拟数字人2
查看详情 阿里云-虚拟数字人

那么,问题来了,我们是不是需要人工为每个应用实例去添加其所需要的依赖库呢?

让我们回忆一下小E用Ghost为其他同学的计算机安装操作系统的场景:

小E在自己的计算机上安装好了Windows ME操作系统(暴露年龄了),以及Office,Matlab和Visual C# .net,并将计算机安装了操作系统和这些应用程序的C盘(第一个磁盘分区)通过Ghost制作为镜像。然后,小E只需要把这个镜像文件恢复到其他计算机的第一个磁盘分区上,其他计算机就和小E的计算机一样,变成了标准化的运行环境,过程只需要几分钟。

我们在《虚拟化与云计算硬核技术内幕(27) —— 健康码与孙大圣(上)》中提到,在云计算环境中,也可以通过这样的方式来快速批量复制虚拟机,而不需要手工在每台虚拟机中部署应用及应用所依赖的各种运行时库。

那么,我们如果剥离掉hypervisor层,能不能自动化发放利用namespace隔离,设定好CGroups资源配额限制,并通过UnionFS虚拟化出文件系统的一个应用进程实例呢?

这种技术就叫做容器(Container)技术,其中,容器运行时引擎(Container Runtime Engine)技术,就是一个自动化实现以上操作的工具

关于容器运行时引擎,让我们下期分解。

今日份段子:

方老师有一个朋友,写招聘JD不小心把售前产品经理打错成收钱产潘金莲,而且发出去了。

以上就是虚拟化与云计算硬核技术内幕 (32) —— 产品经理与潘金莲的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号