首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Cgroup限制资源

使用Cgroup限制资源
EN

Stack Overflow用户
提问于 2015-04-14 20:22:53
回答 1查看 1.3K关注 0票数 0

我的目标是:为用户提供一种限制资源的方法,比如为给定进程(C++)限制CPU、内存。

所以有人建议我使用Cgroup,这看起来是一种理想的实用工具。

在做了一些研究之后,我有一个担忧:

当我们使用memory.limit_in_bytes限制给定进程的内存使用时,是否有办法处理进程中内存不足的异常?我看到控制组提供了一个名为"memory.oom_control“的参数,当它启用时,它会杀死请求内存超过允许的进程。禁用时,它只是暂停进程。

我希望有一种方式让进程知道它请求的内存比预期的多,并且应该抛出内存异常。这样,流程就会优雅地退出。

cgroups是否提供了这样的行为?

cgroup在linux的所有风格中也可用吗?我主要感兴趣的是RHEL 5+,CENTOS 6+和ubuntu 12+机器。

任何帮助都是非常感谢的。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-15 13:57:31

我希望有一种方式让进程知道它请求的内存比预期的多,并且应该抛出内存异常。这样,流程就会优雅地退出。 cgroups是否提供了这样的行为?

最近发行版中的所有进程都已在默认的cgroup中运行。如果您创建了一个新的cgroup,然后将流程迁移到新的cgroup中,那么除了使用来自新cgroup的约束之外,一切都可以像以前一样工作。如果您的进程分配了比允许的内存更多的内存,它将得到一个ENOSPC或malloc故障,就像它目前所做的那样。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29636725

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档