我有一个运行Solaris 10的服务器,它报告70+ GiB空闲内存。我试图在64位模式下使用Java 1.7.0_80启动Tomcat 7.0.68。
服务器声称它无法分配717 MiB的内存。每次尝试时,我都会得到一个hs_err_pidxxx.log文件。它提出如下建议:
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (malloc) failed to allocate 717225984 bytes for committ
我尝试编译QxOrm源码提供的demo,编译时遇到这个报错
cc1plus.exe: out of memory allocating 65536 bytes
诡异的是,每次报错的问题都不一样,而且经过多次编译后,居然成功了。 这是什么原因,我在网上找了很多相关问题,没有跟我这个现象一致的,我该怎么解决这个问题呢?
我有一个Jetty服务器,用于我正在开发的应用程序的websocket连接。唯一的问题是Jetty消耗了太多的虚拟内存(!2.5 of的虚拟内存)和大约650RES。
我的问题是,如上所述,大多数内存(大约12 of )不是堆大小,因此分析它并理解发生了什么变得更加困难。
关于如何理解12 Do的消耗以及如何找出内存泄漏或服务器的任何其他问题,您有什么建议吗?
我想证明我所说的虚拟内存是什么意思(因为我的理解可能是错误的)。当我运行top时,虚拟内存是"VIRT“。下面是我得到的结果:
PID USER PR NI VIRT RES SHR S %CPU %MEM TIM
使用make进行编译时,我得到以下错误(我有cygwin.dll)
*** Couldn't reserve space for cygwin's heap (0x150000) in child, cygheap, Win32 error 0
0 [main] make 4336 sync_with_child: child 2968(0x120) died before initialization with status code 0x1
308 [main] make 4336 sync_with_child: *** chil