我的目标是:为用户提供一种限制资源的方法,比如为给定进程(C++)限制CPU、内存。
所以有人建议我使用Cgroup,这看起来是一种理想的实用工具。
在做了一些研究之后,我有一个担忧:
当我们使用memory.limit_in_bytes限制给定进程的内存使用时,是否有办法处理进程中内存不足的异常?我看到控制组提供了一个名为"memory.oom_control“的参数,当它启用时,它会杀死请求内存超过允许的进程。禁用时,它只是暂停进程。
我希望有一种方式让进程知道它请求的内存比预期的多,并且应该抛出内存异常。这样,流程就会优雅地退出。
cgroups是否提供了这样的行为?
cgroup在linux的所有风格中也可用吗?我主要感兴趣的是RHEL 5+,CENTOS 6+和ubuntu 12+机器。
任何帮助都是非常感谢的。
谢谢
发布于 2015-04-15 13:57:31
我希望有一种方式让进程知道它请求的内存比预期的多,并且应该抛出内存异常。这样,流程就会优雅地退出。 cgroups是否提供了这样的行为?
最近发行版中的所有进程都已在默认的cgroup中运行。如果您创建了一个新的cgroup,然后将流程迁移到新的cgroup中,那么除了使用来自新cgroup的约束之外,一切都可以像以前一样工作。如果您的进程分配了比允许的内存更多的内存,它将得到一个ENOSPC或malloc故障,就像它目前所做的那样。
https://stackoverflow.com/questions/29636725
复制相似问题