本文主要是介绍现场工程师出手--虚拟化软件预留内存过大导致其他程序崩溃问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
项目场景:
一位学生有一台笔记本电脑,安装了Android,Kafka虚拟机很多软件。笔记本配置了20GB内存,固态硬盘,但最近很卡,Android Stuido经常闪退,一些游戏也无法运行。
问题描述
由于Android Studio是很耗内存的软件,首先想到观察内存,发现可用内存不足5%,资源监视器大量“硬中断”报警,说明存在大量的内存分配失败。同时页面缓存也涨到快10GB,更说明是内存不够了。这直接导致开启一些大型3D游戏时卡顿(大量的Page交换),安卓仿真器崩溃。使用进程工具统计所有进程的内存,发现总共才占了6GB不到,那另外12GB内存是谁占用了?
原因分析:
考虑到同学启动了一个debain的虚拟机作为一个本地服务器,测试一些新版本Kafka的功能。会不会是虚拟机的问题呢? 同学也说本来以为是的,但是把虚拟机的内存从8G下降到2GB,还是会内存爆满。
在现场,我再次终止虚拟机后,内存果然全部释放干净了。但这个虚拟机总共才2GB的内存配置,怎么可能占用如此多的内存呢?
我们试着复现现象:
- 重启笔记本,不启动虚拟机时,一切正常。
- 启动虚拟机,开启数据吞吐测试程序。这个程序会不断从虚拟机内存里吞吐大量的数据。
- 资源管理器发现内存缓慢涨大,并轻松突破了2GB的限制,持续膨胀。
- 最终内存全部用光,故障浮现。
这难道是虚拟机本身有内存泄露?由于几次测试,观察到除了正常的系统占用,内存增量基本是16GB左右就不再涨大,狐疑这个16GB是怎么回事。如果是软件故障,应该不会有上限,至少应该把页面文件都撑爆了再退出。但这个现象是由虚拟机占用的内存到达16GB就停止增长了。此时,若不运行别的软件,系统还是正常的。
抱着试一试的态度,在虚拟机设置页面瞎点,改了一堆参数,也没有用。结果,即将黔驴技穷的时候,在虚拟机的“全局配置”选项菜单里,有一个“预留内存”的选项,恰好是16GB多。
把这个预留内存下移到4GB,问题解决。
解决方案:
“预留内存”只要比虚拟机的配置内存大就行了。像同学开1个2GB的Debain,设置个4GB足够了。
可能技术背景解释
不是很熟悉这款软件,但有个猜测:
- 这个“预留内存”应该是指由虚拟机统管的全部内存。
- 虽然客户OS只有 2GB内存,但因为IO频繁,虚拟机软件为避免碎片化,会用所有的16GB预留内存来周转数据。
- 增长期,随着频繁的IO,内存不断涨大。2GB客户机里的new每次都在宿主的这16GB缓存的尾部新增长,而不是重用2GB的空间。
- 稳定期,16GB空间用完,回到头部去找新的空闲位置。
上图中,虽然蓝色的虚拟机2GB内存大小不变,但是在虚拟机预留内存中的位置却时刻变化,并逐步遍历了所有的预留内存。因此,这个“预留内存”如果不是专门用来跑虚机的电脑,千万不要设置太大。如果要吃鸡或者GTA,应该非常谨慎地设置内存。
这篇关于现场工程师出手--虚拟化软件预留内存过大导致其他程序崩溃问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!