私はchrootすることができますDir.chroot
Dir.chroot("/var/chroot/mychroot")
しかし、どうすればchrootから戻ることができますか?
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.pwd を使用して、Dir.chroot を使用する前に現在のパスを保存するだけです。