草庐IT

java - 长时间 GC 在应用程序中暂停

我目前运行的应用程序需要最大堆大小为16GB。目前我使用以下标志来处理垃圾回收。-XX\:+UseParNewGC,-XX\:+UseConcMarkSweepGC,-XX:CMSInitiatingOccupancyFraction=50,-XX\:+DisableExplicitGC,-XX\:+PrintGCDateStamps,-XX\:+PrintGCDetails,-Xloggc\:/home/user/logs/gc.log但是,我注意到在某些垃圾回收过程中,应用程序会锁定几秒钟然后继续运行-这是完全不能接受的,因为它是游戏服务器。可以从我的垃圾收集日志中找到一份文件he

java - 哪些 VM 或 GC 支持 JNI 固定?

GetArrayElements函数族被记录为复制数组或将它们固定到位(并且这样做可以防止压缩垃圾收集器移动它们)。它被记录为比GetPrimitiveArrayCritical更安全、限制更少的替代方案.但是,我想知道哪些VM和/或垃圾收集器(如果有的话)实际固定数组而不是复制它们。 最佳答案 较旧的IBMJVM已固定(1.4及更早版本-即:不是当前的IBMJ9JVM),但从那时起,它们就没有了。一般来说,JVM不喜欢固定,因为它确实会扰乱复制垃圾收集器,而这正是当今大多数生产JVM所做的事情。我不是100%最新的(即:最新的Ja

java - 为什么 WeakHashMap 在 GC 后对值有强引用?

WeakHashMap中的关键对象变得弱可达。并且map应该在GC之后删除条目。但是对值对象的强引用仍然存在。为什么?使用Guava弱键映射观察到相同的行为。预期输出:...refKey.get=nullrefValue.get=null但是我得到了输出:map.keys=[]map.values=[]map.size=0refKey.get=nullrefValue.get=(123)代码:importjava.lang.ref.WeakReference;importjava.util.Map;importjava.util.WeakHashMap;importcom.google

java - 为 Java 音频应用程序调优 GC

我注意到在java中播放音频时,gc中的MarkSweepCompact阶段太长并导致短暂的静音,这是NotAcceptable。所以我需要使用低暂停gc。我尝试过Parallel和CMS,它们似乎工作得更好,因为我认为暂停时间更短,而且它们不像默认的那样频繁地进行完整收集。到目前为止,我已经使用以下ParallelGC选项测试了我的程序:-XX:+UseParallelGC-XX:MaxGCPauseMillis=70对于ConcurrentMarkSweep:-XX:+UseConcMarkSweepGC-XX:+CMSIncrementalMode-XX:+CMSIncremen

java - 有没有办法告诉 JVM 当前正在使用哪种 GC 算法

我正在使用Java5,我们的自定义服务器应用程序需要GC调整,因为有时我们会在高峰时段遇到15-20秒的暂停。我们在服务器类机器上运行Java5,其JVM参数如-server-d64有没有办法知道JVM当前使用的是哪种GC算法?http://docs.oracle.com/javase/1.5.0/docs/guide/vm/gc-ergonomics.html在运行服务器VM的服务器级机器上,垃圾收集器(GC)已从以前的串行收集器(-XX:+UseSerialGC)更改为并行收集器(-XX:+UseParallelGC).您可以通过对java命令使用-XX:+UseSerialGC命

Java CMS GC 行为

我有一个导致产生大量垃圾的应用程序。第一个(也是几乎一个)标准是低GC暂停时间。我使用visualgc工具(和gc日志)尝试不同的GC参数。最佳参数如下。-XX:+UseConcMarkSweepGC-Xmx1172M-Xms600M-XX:+UseParNewGC-XX:NewSize=150M我的应用程序在Java1.6.0_21的SunOS10上运行。硬件是2xCPU四核(uname-X结果是numCPU=8)。问题是观察GC行为,在伊甸园空间创建新对象,直到伊甸园已满。当edenspacefullGC运行时,清除垃圾,如果对象不是死副本到Old-gen(我丢弃'from'&'t

java - Apache POI 3.7 OutOfMemoryError : Java heap space when writing to large no of rows to xlsx files

我需要在xlsx文件中写入超过65000行的结果集。所以,我正在尝试使用ApachePOI3.7。我收到OutOfMemoryError:Java堆空间。除了增加JVM内存似乎无法解决问题外,我该如何解决此问题。简单示例代码:publicstaticvoidmain(String[]args)throwsIOException{Workbookwb=newXSSFWorkbook();CreationHelpercreateHelper=wb.getCreationHelper();Sheetsheet=wb.createSheet("newsheet");//Createarowan

java.lang.OutOfMemoryError : Java heap space while initialising an array 错误

我正在尝试初始化一个大小为10位整数的boolean类型数组。它不断抛出OutOfMemoryException。我已将eclipse的堆空间大小从256增加到1024。有什么我想做的吗?intsize=1000000000;boolean[]primesList=newboolean[size]; 最佳答案 使用java.util.BitSet,与使用boolean数组相比,它会将位打包在八分之一的空间中。boolean数组元素占用1个字节而不是1位的原因是因为(大多数)CPU架构不提供直接读取和写入内存的各个位的能力。PC可以操

java - 关于垃圾回收。为什么我们需要调用 System.gc();?

当引用的对象不再可用于任何变量时,将自动调用垃圾收集。但我想知道为什么我们在自动调用垃圾收集时使用System.gc()显式调用。我们什么时候调用System.gc(); 最佳答案 你不知道。正如您所说,垃圾收集是自动的。System.gc()甚至不强制垃圾回收;这只是对JVM的一个提示,“现在可能是清理一下的好时机”一般来说,试图用System.gc()强制垃圾收集器做你想做的事情是一种被自认为比实际更了解的人应用的hack,或者作为(尝试的)损坏代码的解决方法。多年来我一直在编写Java,但我还没有看到调用System.gc确实

Java HotSpot(TM) 64 位服务器 VM 警告无法打开文件 logs/gc.log,因为没有这样的文件或目录

当我尝试运行时出现此错误RACK_ENV=testberailstesttest/system/service_provider_map_test.rb—seed48088JavaHotSpot(TM)64-BitServerVMwarning:Cannotopenfilelogs/gc.logduetoNosuchfileordirectory然后测试因这个错误而超时Timeoutwhilewaitingforclusterstatus[green]and[1]nodes/Users/patrickward/.rbenv/versions/2.4.1/lib/ruby/gems/2.