内存不足 java应用无法启动

2023-10-20 10:43:21 浏览数 (1)

原因

在启动应用时,发现应用一启动就挂掉,线程号一闪就没了,有点奇怪,查看一下错误日志。报了一个错: 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:释放dentriesinodes 3:释放1 和 2 中说道的的所有缓存

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

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

0 人点赞