启动项目报错 failed; error='Cannot allocate memory' (errno=12)服务器内存不足

Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=128m; support was removed in 8.0
Java HotSpot(TM) 64-Bit Server VM warning: UseCMSCompactAtFullCollection is deprecated and will likely be removed in a future release.
Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x0000000090000000, 1879048192, 0) failed; error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 1879048192 bytes for committing reserved memory.
# An error report file with more information is saved as:
# /data/dubbo/rkang-all-services/hs_err_pid16708.log

报错信息显示项目配置的启动内存比服务器空闲内存更大。

解决办法:由于服务器目前专门用于测试本项目,于是重启,系统内存恢复正常

重启后linux操作系统后,重新启动docker中的容器,启动redis时使用命令

docker run -d --name myredis -p 6379:6379 redis --requirepass "TzRQ76AfejLrBS5Z"创建容器启动并添加密码

报错docker: Error response from daemon: Conflict. The container name "/myredis" is already in use by container "4b70747bc8a7dab6aa266b3114d96e19bdc80e991bb072f9ec647e63fb8ae62e". You have to remove (or rename) that container to be able to reuse that name.
See 'docker run --help'.

之前运行docker容器还没有退出,导致出现容器重名情况

docker rm 4b70747bc8a7dab6aa266b3114d96e19bdc80e991bb072f9ec647e63fb8ae62e
删除镜像id

 

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------

后来多次出现服务器空闲内存不足的情况,经查,是由于每次启动tomcat后,执行tomcat的shutdown.sh脚本关闭容器时都有残留进程占用较多的内存资源,而且重复启动关闭残留进程越来越多,最终使linux系统的可分配内存小于容器启动所需内存,导致项目启动失败。

解决方法:通过ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head取进程占用内存(MEM)最高的前10个进程,

通过:kill -9 进程id

杀死残留进程,free查看内存占用情况,内存已释放,问题解决

  • 8
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
error='Cannot allocate memory' (errno=12)是一个常见的错误,表示JVM无法分配内存。这通常是由于系统的物理内存不足或交换空间不足导致的。当JVM尝试分配一定数量的内存时,操作系统无法提供足够的空闲内存,从而导致JVM崩溃。 解决这个问题的方法有几种。首先,您可以尝试释放一些不必要的进程或内存资源,以腾出更多的可用内存。您可以通过关闭一些不使用的程序或服务来实现这一点。这样,JVM将有更多的内存可用于分配。 另一种解决方法是修改JVM的默认配置,减少其启动时所需的内存。您可以通过调整JVM的堆大小、栈大小等参数来实现这一点。具体的方法取决于您使用的是哪个JVM版本和配置工具。您可以查阅相关文档或参考其他资源来了解如何修改JVM的配置。 此外,您还可以考虑升级系统的物理内存或增加交换空间的大小,以提供更多的可用内存给JVM使用。这可能需要一些硬件或系统配置方面的操作,具体取决于您的环境和需求。 总结来说,error='Cannot allocate memory' (errno=12)错误表示JVM无法分配足够的内存。您可以通过释放不必要的进程或资源、调整JVM的配置或增加系统的物理内存和交换空间来解决这个问题。具体的解决方法取决于您的环境和需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值