AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 535528
Accepted
jac
jac
Asked: 2019-08-15 01:44:41 +0800 CST2019-08-15 01:44:41 +0800 CST 2019-08-15 01:44:41 +0800 CST

为什么 unshare -p 不暗示 -f 和 --mount-proc?

  • 772

手册页指定您可能对使用和--fork创建--mount-procPID 命名空间感兴趣,但为什么这些选项不是默认选项?

process namespace
  • 1 1 个回答
  • 1193 Views

1 个回答

  • Voted
  1. Best Answer
    Thomas Nyman
    2019-08-15T07:22:11+08:002019-08-15T07:22:11+08:00

    Linux 命名空间是使用unshare(2)系统调用创建的。该unshare程序只是系统调用的一个薄包装器,unshare(2)它以一种与底层系统调用一样灵活的方式公开命名空间功能。

    对于大多数命名空间,unshare(2)修改调用进程运行时环境,将其与父命名空间分离,并将其与新的、通常为空的命名空间相关联。例如,从网络命名空间中取消共享自己的进程会立即看到一个没有设备的新的空网络命名空间。

    然而,PID 命名空间的工作方式不同。当unshare()被调用分离一个 PID 命名空间时,它不会修改调用进程的运行环境,而是使 a 之后的子进程fork()进入新的 pid 命名空间,并在新的命名空间内接收 PID 1。initPID 1 是为进程保留的。

    --fork至于和--mount-proc不是默认选项的可能原因:

    • --fork可能不是默认值,因为没有其他命名空间需要 fork,并且将 the--fork作为单独的选项使选项的行为--pid与其他命名空间选项直接映射到unshare(2)标志的方式一致。

    • --mount-proc可能不是默认值,因为它暗示了一个挂载命名空间 ( ),并且除了使用适当的标志之外--mount,这类似于--fork执行其他操作。unshare(2)

    init要正确使用 PID 命名空间,需要一个专门设计用于在新命名空间中扮演角色的特殊程序。在新的 PID 命名空间中,pid与其他进程相比,带有 1 的进程具有三个独特的特征:

    1) 它会自动接收默认的信号处理器。这意味着发送给它的信号将被忽略,除非它显式地向信号处理程序注册信号。

    2) 如果命名空间中的另一个进程在其子进程之前死亡,则其子进程将重新成为具有 pid 1 的进程的父进程。这允许init从进程中收集退出状态,以便内核可以将其从进程表中删除。

    3) 如果 PID 为 1 的进程死亡,则 pid 命名空间中的所有其他进程都将被强制终止,命名空间被销毁。

    由于这些原因,应用程序进程通常不适合在 PID 命名空间内作为 PID 1 运行。

    为各种内核控制资源添加命名空间主要是由容器技术推动的,特别是系统容器,它提供了与传统虚拟机(VMS)非常相似的环境,但没有运行单独的内核模拟虚拟机硬件所带来的开销. 早期,命名空间被引入 Linux 内核(主要在 Linux 2.4.19 - 3.8 之间),PID 命名空间是在 Mount、UTS、IPC 和网络命名空间之后引入的。早期版本unshare开创了不同命名空间选项的预期行为方式。

    在LXC和Docker等成熟的容器框架可用之前,unshare可以将其用作临时实用程序,以在新容器(由新的 PID 命名空间和可能的其他非共享命名空间组成)内生成init守护进程(例如systemd)。这样的框架包括它们自己的用于启动容器的功能,而无需unshare. 现代版本systemd也支持此功能,而无需单独的unshare实用程序。

    • 6

相关问题

  • 如何用名称而不是“ps”中的数字替换用户 ID 和组 ID?

  • 如何获取进程的补充组 ID?

  • `/proc/irq/.../spurious` 包含什么?

  • 父进程可以改变其子进程的环境吗?

  • “弹出”如何让进程关闭文件句柄?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve