0

0

Linux服务器资源隔离教程_cgroups与命名空间实战

舞夢輝影

舞夢輝影

发布时间:2026-01-04 15:17:24

|

622人浏览过

|

来源于php中文网

原创

Linux服务器资源隔离依靠cgroups v2与命名空间协同实现:cgroups限制CPU、内存等资源,命名空间提供PID、网络、挂载等视图隔离,二者结合构成容器底层核心;可手动创建控制组、启用命名空间并组合使用构建轻量隔离环境。

linux服务器资源隔离教程_cgroups与命名空间实战

Linux服务器资源隔离主要靠cgroups(控制组)和命名空间(namespaces)两大机制配合实现:cgroups负责限制、统计、隔离进程组的资源使用(CPU、内存、IO等),命名空间则提供视图隔离(如PID、网络、挂载点等),让进程“看不见”其他进程或系统资源。两者结合,就是容器底层最核心的隔离基础。

用cgroups v2统一管理CPU和内存资源

cgroups v2已取代v1成为主流,支持层级化、统一接口和更精细的资源控制。启用前需确认内核支持(5.0+默认开启)并挂载cgroup2文件系统:

mount -t cgroup2 none /sys/fs/cgroup

创建一个名为webapp的控制组,限制其最多使用2个CPU核心(以CPU配额方式)和1GB内存:

mkdir /sys/fs/cgroup/webapp
echo "200000 100000" > /sys/fs/cgroup/webapp/cpu.max # 200ms/100ms周期,即2核等效
echo "1073741824" > /sys/fs/cgroup/webapp/memory.max

把某个进程(如PID 1234)加入该组:

echo 1234 > /sys/fs/cgroup/webapp/cgroup.procs

后续启动的子进程自动继承该限制。也可用systemd定义.slice单位实现持久化配置,适合服务级隔离。

用命名空间隔离进程视角(PID、网络、挂载)

命名空间不直接限制资源,而是让进程拥有独立的系统视图。常用组合包括:

万彩商图
万彩商图

专为电商打造的AI商拍工具,快速生成多样化的高质量商品图和模特图,助力商家节省成本,解决素材生产难、产图速度慢、场地设备拍摄等问题。

下载
  • PID namespace:进程在内部看到自己是PID 1,无法看到宿主机其他进程
  • Network namespace:独立网卡、IP、路由表、iptables规则
  • MNT namespace:独立挂载点,可chroot或bind mount定制根文件系统

手动创建带PID+网络隔离的命名空间示例:

unshare --pid --net --fork --mount-proc /bin/bash

进入后执行ip link会发现只有lo;用nsenter可跨命名空间调试,比如用宿主机网络命名空间查容器内进程网络连接:

nsenter -t $PID -n ss -tuln

组合使用:运行一个轻量隔离环境(无Docker)

不依赖容器引擎,也能用cgroups + 命名空间搭出最小隔离环境。步骤如下:

  • 创建cgroup v2路径并设好CPU/内存上限
  • unshare启动新命名空间(含pid、net、mnt、uts)
  • 在新命名空间中执行mount --make-rslave /避免挂载传播影响宿主机
  • pivot_rootchroot切换到精简根目录(如Alpine的tar解压目录)
  • 将当前shell PID写入cgroup.procs完成资源绑定

这样就获得了一个有独立进程树、网络、文件系统视图,且受CPU/内存硬限制的轻量运行环境——本质就是Docker run的简化版实现逻辑。

监控与排错关键命令

隔离生效后,及时验证是否按预期工作:

  • cat /sys/fs/cgroup/webapp/cpu.stat 查看CPU节流次数(throttled_time > 0说明被限频)
  • cat /sys/fs/cgroup/webapp/memory.current 实时内存占用,对比memory.max判断是否触发OOM
  • ls -l /proc/$PID/ns/ 看进程所属哪些命名空间(inode号相同表示共享同一namespace)
  • ps --no-headers -o pid,comm,cgroup $PID 快速查看进程归属的cgroup路径

常见问题:进程未被限制?检查是否写入cgroup.procs而非cgroup.threads;网络不通?确认netns内已配置IP并启用lo;OOM被杀?查dmesg | grep -i "out of memory"定位触发进程。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1003

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

56

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

293

2025.12.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

379

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

566

2023.08.10

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

249

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

492

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

396

2024.04.08

mc.js网页版入口地址大全
mc.js网页版入口地址大全

本专题整合了mc.js网页版入口地址大全以及mc.js1.8.8版本汇总,阅读专题下面的文章了解更多详细内容。

34

2026.01.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.6万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号