我一直在观看编程中的一些奇怪的现象已经有一段时间了,因为在Linux系统上默认启用了overcommit.
在我看来,几乎每个高级应用程序(例如,用Java,Python或C#等高级编程语言编写的应用程序,包括用C编写的一些使用大型库(如Qt)的桌面应用程序)都使用疯狂的虚拟操作内存.例如,Web浏览器在使用仅300MB的RAM时分配20GB的内存是正常的.或者对于dektop环境,MysqL服务器,几乎每个java或单声道应用程序等,都要分配数十GB的RAM.
为什么会这样?有什么意义?这有什么好处吗?
我注意到当我在linux中禁用overcommit时,如果桌面系统实际上运行了很多这些应用程序,系统就会变得无法使用,因为它甚至无法正常启动.
最佳答案
在虚拟机中运行代码的语言(如Java(*),C#或Python)通常在启动时分配大量(虚拟)内存.部分内容对于虚拟机本身是必需的,部分预先分配给虚拟机内的应用程序.
对于在直接OS控制下执行的语言(如C或C),这不是必需的.您可以编写动态使用它们实际需要的内存量的应用程序.但是,一些应用程序/框架仍然以这样的方式设计,即它们从操作系统请求一次大块内存,然后自己管理内存,希望它比操作系统更有效.
这有问题:
>它不一定更快.大多数操作系统已经非常聪明地管理他们的内存.优化,测量,优化,测量的规则#1.
>并非所有操作系统都有虚拟内存.有一些非常有能力的人不能运行那些“粗心”的应用程序,假设你可以分配很多&很多“不真实”的记忆没有问题.
>您已经发现,如果您将操作系统从“慷慨”变为“严格”,那么这些记忆力就会落在他们的鼻子上.