CGroup Namespace
Last updated
Last updated
学习与实践 AWS 黑客技术:HackTricks 培训 AWS 红队专家 (ARTE) 学习与实践 GCP 黑客技术:HackTricks 培训 GCP 红队专家 (GRTE)
Cgroup 命名空间是 Linux 内核的一项功能,提供了对在命名空间内运行的进程的 cgroup 层次结构的隔离。Cgroups,即控制组,是一个内核功能,允许将进程组织成层次组,以管理和强制系统资源的限制,如 CPU、内存和 I/O。
虽然 cgroup 命名空间不是我们之前讨论的其他命名空间类型(PID、挂载、网络等)中的一种,但它们与命名空间隔离的概念相关。Cgroup 命名空间虚拟化了 cgroup 层次结构的视图,因此在 cgroup 命名空间内运行的进程与在主机或其他命名空间中运行的进程相比,具有不同的层次结构视图。
当创建新的 cgroup 命名空间时,它以创建进程的 cgroup 为基础开始查看 cgroup 层次结构。这意味着在新的 cgroup 命名空间中运行的进程将仅看到整个 cgroup 层次结构的一个子集,限制在以创建进程的 cgroup 为根的 cgroup 子树内。
在 cgroup 命名空间内的进程将将自己的 cgroup 视为层次结构的根。这意味着,从命名空间内进程的角度来看,它们自己的 cgroup 显示为根,并且它们无法看到或访问其自身子树之外的 cgroup。
Cgroup 命名空间并不直接提供资源的隔离;它们仅提供 cgroup 层次结构视图的隔离。资源控制和隔离仍然由 cgroup 子系统(例如,cpu、内存等)本身强制执行。
有关 CGroups 的更多信息,请查看:
CGroups通过挂载新的 /proc
文件系统,如果使用参数 --mount-proc
,您可以确保新的挂载命名空间具有 特定于该命名空间的进程信息的准确和隔离的视图。
您只能以root身份进入另一个进程命名空间。并且您不能在没有指向它的描述符(如/proc/self/ns/cgroup
)的情况下进入其他命名空间。
学习和实践AWS黑客技术:HackTricks Training AWS Red Team Expert (ARTE) 学习和实践GCP黑客技术:HackTricks Training GCP Red Team Expert (GRTE)