网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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

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

虹口ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联公司的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18982081108(备注:SSL证书合作)期待与您的合作!

其实一点也不神奇——利用了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的原创文章,请关注公众号"汪子熙"


文章标题:Docker和宿主机操作系统文件目录互相隔离的实现原理-创新互联
链接地址:http://bjjierui.cn/article/csoscp.html

其他资讯