• chroot命令


    1、介绍

    chroot,即 change root directory (更改 root 目录)。在 linux 系统中,系统默认的目录结构都是以/,即是以根 (root) 开始的。而在使用 chroot 之后,系统的目录结构将以指定的位置作为根位置。在经过 chroot 之后,系统读取到的目录和文件将不在是旧系统根下的而是新根下(即被指定的新的位置)的目录结构和文件。

    因此它带来的好处大致有以下3个:
    1)增加了系统的安全性,限制了用户的权力;在经过 chroot 之后,在新根下将访问不到旧系统的根目录结构和文件,这样就增强了系统的安全性。这个一般是在登录 (login) 前使用 chroot,以此达到用户不能访问一些特定的文件。
    2)建立一个与原系统隔离的系统目录结构,方便用户的开发;使用 chroot 后,系统读取的是新根下的目录和文件,这是一个与原系统根下文件不相关的目录结构。在这个新的环境中,可以用来测试软件的静态编译以及一些与系统不相关的独立开发
    3)切换系统的根目录位置,引导 Linux 系统启动以及急救系统等。chroot 的作用就是切换系统的根位置,而这个作用最为明显的是在系统初始引导磁盘的处理过程中使用,从初始 RAM 磁盘 (initrd) 切换系统的根位置并执行真正的 init。另外,当系统出现一些问题时,我们也可以使用 chroot 来切换到一个临时的系统。

    2、命令内容

    [root@test ~]# chroot --help
    Usage: chroot [OPTION] NEWROOT [COMMAND [ARG]...]
      or:  chroot OPTION
    Run COMMAND with root directory set to NEWROOT.
    
      --userspec=USER:GROUP  specify user and group (ID or name) to use
      --groups=G_LIST        specify supplementary groups as g1,g2,..,gN
          --help     display this help and exit
          --version  output version information and exit
    
    If no command is given, run '${SHELL} -i' (default: '/bin/sh -i').
    
    GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
    For complete documentation, run: info coreutils 'chroot invocation'
    

    3、操作流程  

    创建一个目录作为根目录,chroot MyRootDir,默认会执行${SHELL} -i,即MyRootDir/bin/bash,所以需要拷贝bash到指定目录,这个在救援模式的情况下,可以简单的判断是否是bash文件缺失导致的系统异常

    mkdir -p testRootDir/bin
    cp /bin/bash testRootDir/bin/

  • 相关阅读:
    conda docker镜像
    知识图谱推理与实践 (2) -- 基于jena实现规则推理
    知识图谱推理与实践(1)
    Docker使用mysqldump命令备份导出mysql容器中的数据
    centos sudo ps查找并kill线程
    使用Docker安装mysql,挂载外部配置和数据
    使用rpm命令查看软件是否安装,卸载、安装软件
    mysql too many connection
    mysql timeout的详细介绍
    git创建/删除本地branch(分支),tag(标签)
  • 原文地址:https://www.cnblogs.com/potato-chip/p/13723205.html
Copyright © 2020-2023  润新知