linux – unshare –pid / bin / bash – fork无法分配内存

前端之家收集整理的这篇文章主要介绍了linux – unshare –pid / bin / bash – fork无法分配内存前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用 linux命名空间.特别是pid命名空间.

我以为我用bash测试了一些东西但遇到了这个问题:

unshare -p /bin/bash
bash: fork: Cannot allocate memory

从那里运行ls给了一个核心转储.退出是唯一可能的事情.

它为什么这样做?

解决方法

错误是由新的命名空间中的PID 1进程退出引起的.

在bash开始运行之后,bash将分叉几个新的子进程来做事.如果在没有-f的情况下运行unshare,bash将具有与当前“unshare”进程相同的pid.当前的“unshare”进程调用unshare systemcall,创建一个新的pid命名空间,但当前的“unshare”进程不在新的pid命名空间中.这是linux内核的理想行为:进程A创建一个新的命名空间,进程A本身不会被放入新的命名空间,只有进程A的子进程将被放入新的命名空间.所以当你跑:

unshare -p /bin/bash

unhare进程将执行exec / bin / bash,而/ bin / bash会分叉几个子进程,bash的第一个子进程将成为新命名空间的PID 1,子进程将在完成其作业后退出.所以新命名空间的PID 1退出.

PID 1进程具有特殊功能:它应该成为所有孤立进程的父进程.如果根命名空间中的PID 1进程退出,则内核将发生混乱.如果子命名空间中的PID 1进程退出,则linux内核将调用disable_pid_allocation函数,该函数将清除该命名空间中的PIDNS_HASH_ADDING标志.当linux内核创建一个新进程时,内核将调用alloc_pid函数在命名空间中分配PID,如果未设置PIDNS_HASH_ADDING标志,则alloc_pid函数将返回-ENOMEM错误.这就是你得到“无法分配内存”错误的原因.

您可以使用’-f’选项解决此问题:

unshare -fp /bin/bash

如果使用’-f’选项运行unshare,unshare将在创建新的pid命名空间后派生一个新进程.并在新进程中运行/ bin / bash.新进程将是新pid命名空间的pid 1.然后bash还会分叉几个子进程来做一些工作.由于bash本身是新pid命名空间的pid 1,因此其子进程可以毫无问题地退出.

猜你在找的Linux相关文章