linux c 利用时间限制程序的使用,Linux使用cgroup限制程序资源

以前一直在使用Docker来封装并限制容器资源,从而实现限制进程资源的目的。但Linux Docker底层是基于cgroup来实现的,于是乎今天就想起来试试直接使用cgroup来限制进程资源。

下面就以要限制一个程序的内存为例,来看看怎么实现限制资源。对于其它的资源限制都可以使用类似方法。

下面进入系统的 /sys/fs/cgroup 目录下,看看我们可以限制哪些资源。在这个目录下,基本上每个目录代表一类资源。这里以memory资源为例,memory目录下包括下面这些文件

其中

带 memsw 的表示虚拟内存,不带 memsw 的表示物理内存;

memory.limit_in_bytes:是用来限制内存使用的;

memory.memsw.limit_in_bytes:内存+swap空间使用的总量限制,memory.memsw.limit_in_bytes 必须大于或等于 memory.limit_in_byte;

memory.oom_control:内存超限之后的 oom 行为控制,0 为开启此功能;

memory.use_hierarchy:当设为 1 时,子控制组进程的内存占用也会计入父控制组,并上溯到所有 memory.use_hierarchy = 1 的祖先控制组,默认为 0;

下面就看看怎样使用 cgroup 来限制进程内存。

首先在 /sys/fs/cgroup/memory 目录下创建一个 mem_test 目录,创建后会发下 mem_test 目录下会默认创建床很多文件,大多数和 /sys/fs/cgroup/memory 目录下的文件类似。

# cd /sys/fs/cgroup/memory/

# mkdir mem_test

# cd mem_test

# echo 1024M > memory.limit_in_bytes

# echo 0 > memory.oom_control

# echo 1 > memory.use_hierarchy

然后运行测试程序,同时使用 ps 和 top 命令来监控程序执行,可以发现当程序内存超过1G后,程序就会被 kill 掉。

# cgexec -g memory:mem_test ./mem.py 2GB

1

这里我们只使用了一种资源限制,如果要组合多种资源限制可以使用类似如下的方法:

cgexec -g *:

cgexec -g cpu,memory:

cgexec -g cpu,memory: -g swap:

原文链接:https://blog.csdn.net/kongxx/article/details/98329891

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值