原因
在启动应用时,发现应用一启动就挂掉,线程号一闪就没了,有点奇怪,查看一下错误日志。报了一个错: Invalid initial heap size: -Xms9g
完整日志如下
代码语言:javascript复制Thu May 19 18:14:59 CST 2016
Invalid initial heap size: -Xms9g
The specified size exceeds the maximum representable size.
Error: Could not create the Java Virtual Machine.
Error: A fatal exception has occurred. Program will exit.
[java-tron@chaindev010 FullNodeHelloMessage]$ java -version
java version "1.8.0_161"
Java(TM) SE Runtime Environment (build 1.8.0_161-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.161-b12, mixed mode)
这个机器有16G内存,有可能是内存被占用完了,查看一下内存
代码语言:javascript复制free -g
只使用了6,free只存1G,这明显是有缓存。
代码语言:javascript复制 total used free shared buff/cache available
Mem: 15 6 1 0 7 8
Swap: 0 0 0
清理缓存
清理的方式就是修改系统的默认页缓存配置。
代码语言:javascript复制echo 1 > /proc/sys/vm/drop_caches
空间马上腾出来了,再启动就解决问题了。
代码语言:javascript复制 total used free shared buff/cache available
Mem: 15 6 8 0 0 8
Swap: 0 0 0
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来释放内存。