我可以用 chrootDir.chroot
Dir.chroot("/var/chroot/mychroot")
但是我怎样才能从 chroot 返回呢?
a的重点chroot
是你不能出去。但是,如果您不这样做chdir
,/var/chroot/mychroot
那么您仍然可以使用.
, 和访问外部文件系统..
我不太了解 Ruby,但这是 Python 中的诀窍:
/tmp$ sudo python
>>> import os
>>> os.chroot("/var")
>>> os.listdir("/") # list our new root
['backups', 'log', 'opt', 'cache', 'spool', 'lib', 'local', 'run', 'lock', 'games', 'mail', 'tmp']
>>> os.listdir(".") # list a directory outside our jail
['.X0-lock', '.ICE-unix', '.X11-unix']
>>> os.listdir("..") # list the outside root
['lost+found', 'bin', 'mnt', 'boot', 'opt', 'scratch', 'var', 'proc', 'usr', 'etc', 'lib', 'srv', 'sys', 'media', 'root', 'selinux', 'vmlinuz', 'dev', 'tmp', 'home', 'sbin']
在 chroot 之前,将对当前根目录的引用保存为文件描述符。
要将设置当前工作目录返回到文件描述符,然后 chroot 到.
.
示例 python 会话:
$ unshare -r python3
Python 3.8.2 (default, Apr 27 2020, 15:53:34)
[GCC 9.3.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import os
>>> f = os.open("/", os.O_PATH)
>>> os.chdir("/mnt")
>>> os.chroot(".")
>>> os.listdir(".")
[]
>>> os.listdir("/")
[]
>>> os.chdir(f)
>>> os.chroot(".")
>>> os.listdir("/")
['bin', 'lib', 'lib64', 'sbin', 'boot', 'btrfs', 'btrfs_ssd', 'cdrom', 'dev', 'etc', 'home', 'media', 'mnt', 'opt', 'proc', 'root', 'run', 'snap', 'srv', 'sys', 'tmp', 'usr', 'var', 'secure']
或者,将当前工作目录设置为旧根目录。
只需在使用 Dir.chroot 之前保存当前路径,使用 Dir.pwd