内存不足 java应用无法启动
原因
在启动应用时,发现应用一启动就挂掉,线程号一闪就没了,有点奇怪,查看一下错误日志。报了一个错: Invalid initial heap size: -Xms9g
完整日志如下
1 | Thu May 19 18:14:59 CST 2016 |
这个机器有16G内存,有可能是内存被占用完了,查看一下内存
1 | free -g |
只使用了6,free只存1G,这明显是有缓存。
1 | total used free shared buff/cache available |
清理缓存
清理的方式就是修改系统的默认页缓存配置。
1 | echo 1 > /proc/sys/vm/drop_caches |
空间马上腾出来了,再启动就解决问题了。
1 | total used free shared buff/cache available |
drop_caches 命令
drop_caches的值可以是0-3之间的数字,代表不同的含义:
0:不释放(系统默认值)
1:释放页缓存
2:释放dentries
和inodes
3:释放1 和 2 中说道的的所有缓存
也就是说
数字1: 是用来清空最近放问过的文件页面缓存
数字2: 是用来清空文件节点缓存和目录项缓存
数字3: 是用来清空1和2所有内容的缓存。
/proc
是一个虚拟文件系统,我们可以通过对它的读写操作作为与kernel实体间进行通信的一种手段。
也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。
也就是说我们可以通过调整/proc/sys/vm/drop_caches来释放内存。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 人话翻译机!
评论