C++ 内存过量使用 Linux
C++ memory overcommit Linux
我目前正在编写一个基本上为客户端处理工作负载的服务器应用程序。根据实际工作负载,服务器可能会使用大量内存。目标平台是 Windows 和 Linux,代码是用 c++ 编写的。
但是,我对 linux 编程不是很熟悉,在今天的一些测试中,我 运行 遇到了一些奇怪的崩溃。事实证明,这些与内存过度使用有关。
我写的代码相当健壮,可以处理内存不足的情况(至少在 Windows 系统上),只要它 运行 进入 [=] 24=] 异常。
重构所有代码以应对由于过度使用内存而可能发生的错误将是一场彻头彻尾的噩梦。
所以,我想知道是否可以为我的进程和子线程关闭过度使用。我已经在这里 Link(在 Whosebug)发现了一个老问题,它回答“否”,但意识到这是一个 10 年前的答案,我想知道它是否已经改变?
如果仍然无法明智地改变这个应用程序,是否至少有一种方法可以在我的应用程序中检测它的当前设置?
提前致谢!
So, i was wondering if i could turn off overcommit for my process and child threads. I already found an old question here Link (at Whosebug) that answers this as no, but realizing that this is a 10 year old answer i was wondering if that might have changed?
不,您仍然无法更改每个进程的过量使用设置。这是一个系统范围的设置。只有超级用户权限才能更改。
is there at least a way of detecting the current setting
您可以从 /proc 伪文件系统读取它。特别是文件 /proc/sys/vm/overcommit_memory
.
我目前正在编写一个基本上为客户端处理工作负载的服务器应用程序。根据实际工作负载,服务器可能会使用大量内存。目标平台是 Windows 和 Linux,代码是用 c++ 编写的。
但是,我对 linux 编程不是很熟悉,在今天的一些测试中,我 运行 遇到了一些奇怪的崩溃。事实证明,这些与内存过度使用有关。
我写的代码相当健壮,可以处理内存不足的情况(至少在 Windows 系统上),只要它 运行 进入 [=] 24=] 异常。 重构所有代码以应对由于过度使用内存而可能发生的错误将是一场彻头彻尾的噩梦。
所以,我想知道是否可以为我的进程和子线程关闭过度使用。我已经在这里 Link(在 Whosebug)发现了一个老问题,它回答“否”,但意识到这是一个 10 年前的答案,我想知道它是否已经改变?
如果仍然无法明智地改变这个应用程序,是否至少有一种方法可以在我的应用程序中检测它的当前设置?
提前致谢!
So, i was wondering if i could turn off overcommit for my process and child threads. I already found an old question here Link (at Whosebug) that answers this as no, but realizing that this is a 10 year old answer i was wondering if that might have changed?
不,您仍然无法更改每个进程的过量使用设置。这是一个系统范围的设置。只有超级用户权限才能更改。
is there at least a way of detecting the current setting
您可以从 /proc 伪文件系统读取它。特别是文件 /proc/sys/vm/overcommit_memory
.