当前位置: 首页 > 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 中,如果 -r 删除, 会是什么效果 ?

会创建一个新的user namespace,但是没鸟用,等于是一个空的壳子。linux下 ,资源必须有父子关系,才能进行管理。

此时要么不用这个新的资源,要么再手动给资源添加父子关系。

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.mrgr.cn/news/81395.html

相关文章:

  • Squeeze-and-Excitation (SE) 模块
  • UE5.3 C++ Ceiusm中的POI 制作3DUI 结合坐标转化
  • 如何永久解决Apache Struts文件上传漏洞
  • 迈向未来:.NET技术的持续创新与发展前景
  • cudnn版本gpu架构
  • 消息队列(一)消息队列的工作流程
  • JdbcTemplate、NamedParameterJdbcTemplate 执行数据插入后返回主键写法
  • Pytorch | 利用I-FGSSM针对CIFAR10上的ResNet分类器进行对抗攻击
  • acme ssl证书自动续签 nginx
  • Android U 多任务启动分屏——system_server流程(更新中)
  • 【Linux】ChatGLM-4-9B模型之All Tools
  • 【目标跟踪综述及关键技术】
  • 重温设计模式--2、设计模式七大原则
  • 人工智能ACA(六)--计算机视觉基础
  • js版本之ES6特性简述【Proxy、Reflect、Iterator、Generator】(五)
  • 时钟芯片入门指南:从原理到实践
  • 消息队列(一)消息队列的工作流程
  • 【老白学 Java】HashMap 的基本使用
  • 项目代码第6讲:UpdownController.cs;理解 工艺/工序 流程、机台信息;前端的“历史 警报/工艺 记录”;每个机台各个管道的数据(温度、压力、气体)
  • 【python】银行客户流失预测预处理部分,独热编码·标签编码·数据离散化处理·数据筛选·数据分割
  • postman http请求正常,使用前端代理服务器报403
  • 使用Qwen2-VL模型批量标注图像内容(图像理解)
  • YOLOv11模型改进-模块-引入多尺度大核注意力Multi-scale Large Kernel Attention
  • 【阅读记录-章节6】Build a Large Language Model (From Scratch)
  • 机器学习2-NumPy
  • 使用RabbitMQ