iis服务器助手广告广告
返回顶部
首页 > 资讯 > 操作系统 >Docker和宿主机操作系统文件目录互相隔离的实现原理
  • 122
分享到

Docker和宿主机操作系统文件目录互相隔离的实现原理

2023-06-04 13:06:48 122人浏览 独家记忆
摘要

我们知道在Docker容器里是无法访问到宿主操作系统的文件目录的,但这种隔离是怎么实现的呢?其实一点也不神奇——利用了linux系统的内部命令chroot。chroot能将进程的根目录设置成任意指定的目录。使用chroot我们能创建一个新的

我们知道在Docker容器里是无法访问到宿主操作系统的文件目录的,但这种隔离是怎么实现的呢?

其实一点也不神奇——利用了linux系统的内部命令chroot。

chroot能将进程的根目录设置成任意指定的目录。

Docker和宿主机操作系统文件目录互相隔离的实现原理

使用chroot我们能创建一个新的进程,并且以chroot执行时传入的参数作为新进程的根目录。

因为新进程创建之后就无法访问除了新进程创建时传入chroot参数之外的其他文件目录,为了确保这个新进程能够正常工作,我们必须手动拷贝一些文件到新进程的根目录映射的旧目录下。

做一个如下测试

新建一个文件夹,执行chroot . 意思是把文件夹$HOME/container当作新建进程的根目录。但是没有成功,报错误消息chroot: failed to run command ‘/bin/bash’: No such file or directory

Docker和宿主机操作系统文件目录互相隔离的实现原理

执行下面两条命令:

Docker和宿主机操作系统文件目录互相隔离的实现原理

执行命令ldd $HOME/container/bin/bash:

该命令为了查看需要有哪些库文件得手动拷贝到文件夹$/HOME/container/bin/bash下面:

Docker和宿主机操作系统文件目录互相隔离的实现原理

根据ldd的输出,再次执行下图的八条命令:

Docker和宿主机操作系统文件目录互相隔离的实现原理

Docker和宿主机操作系统文件目录互相隔离的实现原理

再次执行chroot . , 发现这次成功了:

Docker和宿主机操作系统文件目录互相隔离的实现原理

pwd发现是在根目录下,ls也只能发现执行chroot时指定的container目录下的子目录:

Docker和宿主机操作系统文件目录互相隔离的实现原理

这就是docker文件目录隔离的实现原理。

要获取更多Jerry的原创文章,请关注公众号"汪子熙"

--结束END--

本文标题: Docker和宿主机操作系统文件目录互相隔离的实现原理

本文链接: https://www.lsjlt.com/news/238134.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Docker和宿主机操作系统文件目录互相隔离的实现原理
    我们知道在Docker容器里是无法访问到宿主操作系统的文件目录的,但这种隔离是怎么实现的呢?其实一点也不神奇——利用了Linux系统的内部命令chroot。chroot能将进程的根目录设置成任意指定的目录。使用chroot我们能创建一个新的...
    99+
    2023-06-04
  • 如何实现Windows宿主系统和虚拟机ubuntu系统文件互相访问
    今天就跟大家聊聊有关如何实现Windows宿主系统和虚拟机ubuntu系统文件互相访问,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。我的宿主操作系统是Windows 10,使用Ora...
    99+
    2023-06-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作