当前位置: 首页 > news >正文

【linux】 unshare -user -r /bin/bash命令详解

命令解析

unshare -user -r /bin/bash 是一个 Linux 命令,它用于在新的用户命名空间中运行一个进程(在这个例子中是 /bin/bash)。以下是这个命令的详细解释:
【1. 命令解析】

  • unshare:

    • unshare 是一个工具,用于从调用进程中分离某些资源的命名空间(namespace)。
    • 它允许创建新的命名空间并在其中运行进程。
  • -user:

    • 创建一个新的用户命名空间。
    • 用户命名空间允许非特权用户映射当前用户自己的用户和组 ID
    • 在新命名空间中,当前用户可以表现为 root,即 UID 为 0。
  • -r:

    • 自动将当前用户映射为新用户命名空间的 root 用户。
    • 在新命名空间中,用户实际上是普通用户,但可以以 root 的身份运行。

    注意:不能单独存在,依赖前面的--user参数

  • /bin/bash:

    命令运行一个新的 Bash shell,使其在创建的用户命名空间中运行。

【2. 效果】

运行 unshare -user -r /bin/bash 后:

  • 用户命名空间创建:

    • 系统会创建一个新的用户命名空间。
    • 在此命名空间中,当前用户的 UID 会被映射为 0(root)。
    • 但命名空间的 root 并不是真正的全局 root,权限仅限于命名空间内部
  • 获得伪 root 权限:

    • 在新命名空间中,用户看起来是 root(UID=0)。
    • 但实际上,它与真实的全局 root 不同,限制在新命名空间的范围内。
  • 独立环境:

    对命名空间内部的修改(如文件系统、权限等)不会影响全局系统。

unshare -user -r /bin/bash 中,如果 -user 删除, 会是什么效果

unshare -r /bin/bash 能执行吗?

这种情况下,不会创建用户命名空间,而仅执行 -r 标志的作用,但其行为依赖于是否指定了其他命名空间类型(例如 --mount、–net 等)。以下是具体分析:

-r 标志的作用:

  • 如果存在用户命名空间(–user),-r 会将当前用户映射为命名空间内的 root。
  • 如果没有用户命名空间,-r 是无意义的,或者可能会报错,因为没有地方可以映射 UID

注意:此命令unshare -r /bin/bash 扔能执行,可能有默认值,例如指定了 --user--pid

http://www.lryc.cn/news/509058.html

相关文章:

  • 微软远程桌面APP怎么用
  • Android9.x SurfaceView源码分析
  • MDS-NPV/NPIV
  • 通用人工智能的关键:统一语言描述万物
  • JSON 系列之1:将 JSON 数据存储在 Oracle 数据库中
  • [前端]HTTP库Axios
  • vue3入门教程:reactive函数
  • SDMTSP:黑翅鸢算法(Black-winged kite algorithm,BKA)求解单仓库多旅行商问题,可以更改数据集和起点(MATLAB代码)
  • 叉车作业如何确认安全距离——UWB测距防撞系统的应用
  • 5-Gin 静态文件服务 --[Gin 框架入门精讲与实战案例]
  • 【自动驾驶】3 激光雷达③
  • Vue 3.5 编写 ref 时,自动插入.Value
  • 从0到1实现一个RS蓝图系统-概念提出技术栈选型
  • npm淘宝镜像
  • 深入解析:Python中的决策树与随机森林
  • 奇怪问题| Chrome 访问csdn 创作中心的时候报错: 服务超时,请稍后重试
  • 【Leetcode】1705. 吃苹果的最大数目
  • 职业技能赛赛后心得
  • 从AI换脸到篡改图像,合合信息如何提升视觉内容安全?
  • c# 实现一个简单的异常日志记录(异常迭代+分片+定时清理)+AOP Rougamo全局注入
  • webrtc学习----前端推流拉流,局域网socket版,一对多
  • 美国加州房价数据分析01
  • 用Python开启人工智能之旅(四)深度学习的框架和使用方法
  • 两分钟解决:vscode卡在设置SSH主机,VS Code-正在本地初始化VSCode服务器
  • 信号仿真高级工程师面试题
  • 循环和迭代
  • 一个简单封装的的nodejs缓存对象
  • 【Rust自学】5.3. struct的方法(Method)
  • ChatGPT之父:奥尔特曼
  • 如何在谷歌浏览器中设置桌面快捷方式