0

0

Linux如何管理容器资源_限制CPU与内存的cgroups机制深入理解【技巧】

冷漠man

冷漠man

发布时间:2025-12-23 22:39:08

|

219人浏览过

|

来源于php中文网

原创

Linux容器资源管理核心是cgroups内核级强制隔离,CPU通过cfs_period_us与cfs_quota_us控制(如quota=200000/period=100000=2核),内存需同时设memory.limit_in_bytes和memory.memsw.limit_in_bytes防swap绕过,绑定推荐cgexec启动,验证须查cgroup原生接口而非top。

linux如何管理容器资源_限制cpu与内存的cgroups机制深入理解【技巧】

Linux容器资源管理的核心,就是靠 cgroups 实现的硬性隔离与精准控制。它不是“建议”或“调度倾向”,而是内核级强制限制——超限就杀进程(如内存OOM)、超时就暂停调度(如CPU配额用尽)。理解关键参数和操作逻辑,比死记命令更重要。

CPU 限制:别只看百分比,要看周期与配额

cgroups 控制 CPU 不是靠“占用率”这个结果,而是通过 cfs_period_us(调度周期)和 cfs_quota_us(该周期内允许使用的 CPU 时间)两个值共同决定的。实际可用 CPU 核心数 = quota / period。

  • 默认周期是 100000 微秒(即 100ms),若设 quota = 50000,则等效为 0.5 个核心(50% 单核)
  • 想限制为 2 个完整核心:quota = 200000,period = 100000
  • 想限制为 4 核服务器上的 75% 总算力(即 3 核):quota = 300000,period = 100000
  • 注意:quota 可大于 period,但不能小于 1000(即 1ms),否则会被内核拒绝

内存限制:物理上限 + swap 容量要分开管

内存控制的关键文件是 memory.limit_in_bytes,但它只管物理内存。如果不限制 swap,进程仍可能把数据换出到磁盘,绕过物理内存限制。

  • 设物理内存上限为 2GB:echo 2147483648 > memory.limit_in_bytes
  • 同时限制“内存+swap”总和为 2.5GB:echo 2684354560 > memory.memsw.limit_in_bytes
  • 一旦进程申请内存导致总用量突破 memsw 上限,OOM Killer 就会介入并终止最“可杀”的进程
  • 不建议关闭 swap,但必须显式配置 memsw,否则 memory.limit_in_bytes 形同虚设

绑定进程:启动时绑定比运行中迁移更可靠

把服务进程纳入 cgroup,有两种主流方式,推荐优先用第一种:

AI Content Detector
AI Content Detector

Writer推出的AI内容检测工具

下载
  • cgexec 启动:sudo cgexec -g cpu,memory:/myapp ./myserver —— 进程从诞生起就受控,无遗漏风险
  • cgclassify 迁移已有进程:sudo cgclassify -g cpu,memory:myapp $(pgrep myserver) —— 需确认 PID 准确,且子进程未必自动继承
  • systemd 用户可直接在 service 文件里加 Slice= 字段,让整个服务天然落入指定 cgroup 层级

验证与调试:别只信 top,要用原生接口查

top、htop 显示的是瞬时负载,无法反映 cgroups 的真实配额执行情况。应直接读取 cgroup 接口文件或使用 pidstat:

  • 查某 cgroup 当前 CPU 使用总量:cat cpu.stat(含 nr_periods、nr_throttled、throttled_time)
  • 查是否被限频:throttled_time > 0 表示该组已被 throttle 过
  • 查内存实际用量:cat memory.usage_in_bytescat memory.max_usage_in_bytes
  • pidstat -r -p $(pgrep myapp) 看 RSS 是否逼近 limit_in_bytes

基本上就这些。cgroups 不复杂但容易忽略细节,尤其是 period/quota 的数学关系和 memsw 的必要性。只要参数设对、绑定及时、验证到位,容器资源就不会“飘”。

相关专题

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

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

1018

2023.10.19

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

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

63

2025.10.17

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

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

405

2025.12.29

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1348

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

701

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

572

2023.07.06

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

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

精品课程

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

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

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

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