Linux 下使用 cgroup 控制进程的cpu,内存

简介

Cgroups是 control groups 的缩写,是 Linux 内核提供的一种可以限制、记录、隔离进程组( process groups )所使用的物理资源(如: cpu,memory,IO 等等)的机制。最初由 google 的工程师提出,后来被整合进 Linux 内核。

环境

 Ubuntu 16.04 LTS

Cgroup 安装

% apt install cgroup-bin cgroup-tools cgroup-lite 

相关术语

任务(task),控制族群(control group),层级(hierarchy),子系统(subsytem

可在 /sys/fs/cgroup/目录下查看已经挂载的子系统

使用方法

控制 cpu

% cd /sys/fs/cgroup/cpu
% mkdir test && cd test                   # 新建 控制族群,其中自动会生成一系列文件
% echo 50000 > cpu.cfs_quota_us           # 设置 cpu 使用率为50% (将 cpu.cfs_quota_us 中的值除以 cpu.cfs_period_us 中的值)
% echo 12345 > tasks                      # 将进程id写入tasks
% cd .. && rmdir test                     # 删除 控制族群

可以发现进程cpu使用率不会超过50%


控制 内存

% cd /sys/fs/cgroup/memory
% mkdir test && cd test                   # 新建 控制族群,其中自动会生成一系列文件
% echo 1M > memory.limit_in_bytes         # 设置内存使用上限是 1M
% echo 12345 > tasks                      # 将进程id写入tasks
% cd .. && rmdir test                     # 删除 控制族群
当进程内存使用超过1M时,会触发OOM( out of memory ),进程会被 kill 掉

注意

当某个进程加入了某个控制族群,它之后产生的子进程也会自动加入
% echo $$
28259
% echo $$ > tasks 
% cat tasks
28259
28304
进程 28304 是 cat 进程

参考文章



  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值