编译安卓源码报错:OpenJDK 64-Bit Server VM warning:INFO:os::commit_memory(...)failed; error='...' (errno=12)

一、出错原因

  容易发生在编译安卓6.0以上版本时出现,也跟电脑配置Linux系统时SWAP空间分配过少有关系,常发生在Linux Ubuntu上,在编译占用内存巨大的项目如Android时就可能出现。常出现错误代码提示:errno12: Cannot allocate memory。意思是OpenJDK申请到的内存不足,无法进行后续编译,解决办法有三个:
1、通过free -h命令确认自己电脑的SWAP空间大小,看空间大小是不是足够;
2、在SWAP空间分配合理的情况下可以尝试增加内存条;
3、调整JVM的堆内存大小,因为JVM程序启动时可能会申请比较大的内存,而你物理内存本身又不是很大的情况下就可能出问题。
第三点我没有尝试过,下面重点说明第1点的解决办法。

二、分配重新分配SWAP分区大小

总共分为几部,具体如下:

1. 查看SWAP大小

执行如下命令查看swap空间初始分配大小:

$free -h

可以看到如下图所示情况:
在这里插入图片描述
未分配好的图片找不到了,上面的是我已经分配好SWAP空间的图片。

2. 创建SWAP文件及分配大小

这里使用自己创建SWAP文件,名字可以随便取,为了方便我就取成SWAPfile,先切换成root用户,再执行如下命令:

#dd if=/dev/zero of=/SWAPfile bs=1M count=16384

解释一下:
if=文件名:输入文件名,缺省为标准输入。即指定源文件。< if=input file >
of=文件名:输出文件名,缺省为标准输出。即指定目的文件。< of=output file >
ibs=bytes:一次读入bytes个字节,即指定一个块大小为bytes个字节。
obs=bytes:一次输出bytes个字节,即指定一个块大小为bytes个字节。
bs=bytes:同时设置读入/输出的块大小为bytes个字节。
count=blocks:仅拷贝blocks个块,块大小等于ibs指定的字节数。
这里bs=1M,意味着输入输出块的大小为1MBytes,count=16384意味着我总共给这个将来的SWAP分区文件分配了1M * 16384 = 16G的空间。

3. 设置权限

终端中进入root(也可以不进入),输入如下命令:

chmod 0600 /SWAPfile
4. 将自定义文件变成swap文件:
#mkswap /SWAPfile
5. 配置启动文件

,如果只是在终端里面配置好SWAP就不管了,那么在下次重新启动PC的时候SWAP又变成初始的默认值了,这里需要将其设置成启动时默认挂载swap空间,命令如下:

#vim /etc/fstab

在最末增加新的一行

/SWAPfile          swap       swap     defaults       0       0      
6. 挂载启动swap空间
#swapon    /SWAPfile

到这里就配置完全部流程了,可以执行 free -h 命令看看swap空间的大小是否有改变,最后再重新启动电脑,执行 free -h 看是否依然生效。

7. 其他

如果已经存在SWAPfile(例如:/SWAPfile),那么先执行如下三条删除掉之前的文件:

#swapoff  /SWAPfile      
#unmount /SWAPfile
#vim /etc/fstab
#编辑删除开头为SWAPfile的那一行
#rm -rf /SWAPfile

再执行 free -h ,检查是否依然存在swap空间。

你可能感兴趣的:(Linux学习笔记)