原因

在启动应用时,发现应用一启动就挂掉,线程号一闪就没了,有点奇怪,查看一下错误日志。报了一个错: Invalid initial heap size: -Xms9g

完整日志如下

1
2
3
4
5
6
7
8
9
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内存,有可能是内存被占用完了,查看一下内存

1
free -g

只使用了6,free只存1G,这明显是有缓存。

1
2
3
              total        used        free      shared  buff/cache   available
Mem: 15 6 1 0 7 8
Swap: 0 0 0

清理缓存

清理的方式就是修改系统的默认页缓存配置。

1
echo 1 > /proc/sys/vm/drop_caches

空间马上腾出来了,再启动就解决问题了。

1
2
3
              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:释放dentriesinodes
3:释放1 和 2 中说道的的所有缓存

也就是说
数字1: 是用来清空最近放问过的文件页面缓存
数字2: 是用来清空文件节点缓存和目录项缓存
数字3: 是用来清空1和2所有内容的缓存。

/proc是一个虚拟文件系统,我们可以通过对它的读写操作作为与kernel实体间进行通信的一种手段。
也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。
也就是说我们可以通过调整/proc/sys/vm/drop_caches来释放内存。