前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >内存不足 java应用无法启动

内存不足 java应用无法启动

作者头像
潇洒
发布2023-10-20 10:43:21
7430
发布2023-10-20 10:43:21
举报
文章被收录于专栏:石头岛

原因

在启动应用时,发现应用一启动就挂掉,线程号一闪就没了,有点奇怪,查看一下错误日志。报了一个错: 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来释放内存。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-05-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 原因
  • 清理缓存
  • drop_caches 命令
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档