最近我们开始使用YJP11.0.9对我们的应用程序(基于XMPP的聊天服务器)进行压力测试。在我们的测试过程中,我们注意到以下奇怪的行为。采样显示sun.misc.Unsafe.unpark(Object)占用了60%的CPU。对于同一个应用,Tracing显示LockSupport.park(Object)占用了52%的CPU。我做了多次测试来确认结果,每次我都得到相似的结果。我无法理解为什么unpark应该花费60%的时间以及为什么跟踪显示完全相反的结果。谁能帮我理解这些结果。我在这里遗漏了什么吗?环境:java-versionjavaversion"1.6.0_31"Java(T
当我尝试使用storm在本地模式下运行拓扑时出现此错误mvncompileexec:java-Dexec.classpathScope=compile-Dexec.mainClass=my.Topology错误是ERRORbacktype.storm.util-Asyncloopdied!java.lang.OutOfMemoryError:Physicalmemoryusageistoohigh:physicalBytes=3G>maxPhysicalBytes=3G我该如何解决?我不知道我应该增加哪个物理内存!如果我在生产模式下运行拓扑,这个错误会消失吗?UPDATEPhysica
我目前正在运行一些JMeter测试来测试Web服务的性能。它使用了大量的CPU。对于一个JMeter请求线程,它使用10-30%(取决于请求类型)。当我将其增加到仅15个线程时,我的CPU利用率约为95%。自然,我想弄清楚发生了什么。我做了一个HprofCPU示例(我尝试了times选项,但需要一个半小时才能启动我的服务,并且没有消息会通过)。以下是该采样的结果片段(超过15分钟)。CPUSAMPLESBEGIN(total=220846)FriAug2213:38:542014rankselfaccumcounttracemethod114.96%14.96%33038300514j
问候-我们在工作中遇到了一些喜欢使用的疯子while(true){//Code}在他们的代码中。正如您可以想象的那样,这会最大限度地利用CPU。有谁知道降低CPU使用率以便其他人也可以使用服务器的方法。代码本身只是不断地轮询互联网以获取网站上的更新。因此我想稍微sleep的方法会大大降低CPU使用率。此外,所有操作都是在String对象(Java)中完成的,有人知道StringBuilder会减少多少开销吗?感谢指点 最佳答案 很多关于StringBuilder的“民间智慧”都是不正确的。例如,改变这个:Strings=s1+":"
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:WouldamultithreadedJavaapplicationexploitamulti-coremachineverywell?我的双核机器(WindowsXP32位环境)上有一个像这样的简单Java线程运行publicstaticvoidmain(String[]strs){longj=0;for(longi=0;i我的期望是它会坚持使用单个CPU来充分利用高速缓存(因为在循环中我们一直使用局部变量j,因此一个CPU利用率将是100%,而另一个几乎是虚度。令我惊讶的是,线程启动后,两个CPU的利用率
我用在Linux服务器上运行的Java编写服务器端应用程序。我使用hibernate打开数据库session,使用nativesql查询它并始终通过try、catch、finally关闭此session。我的服务器以非常高的频率使用hibernate查询数据库。我已经定义了MaxHeapSize因为它是3000M但它通常在RAM上使用2.7GB,它可以减少但比增加慢。有时它会增长到3.6GB内存使用量,超过我在启动时定义的MaxHeapSize。当使用的内存为3.6GB时,我尝试使用-jmap命令将其转储并得到一个大小仅为1.3GB的堆转储。我用eclipseMAT来分析,这里是MAT
我有104k个字符串值,其中89k个是唯一的。我想检查这个列表中是否存在一个字符串。这是我的类及其保存所有这些记录的方法。publicclassTestClass{privatestaticTestClasssingletonObj=null;privateListstringList=null;publicstaticsynchronizedTestClassgetInstance(){if(singletonObj==null){singletonObj=newTestClass();}returnsingletonObj;}publicbooleanisValidString(S
根据我今天的经验,我发现Oracle的JavaVisualVM将cpu使用率显示为总机器内核的百分比,即使被监视的JVM在操作系统中设置了有限的进程亲缘关系也是如此。这是在“监视器”选项卡中。使用taskset(在linux、Ubuntu上)限制受监控的jvm,当允许该jvm的处理器在htop中接近100%利用率时,cpu百分比显示在VisualVM显然等于cpu总数除以被监控的jvm允许的处理器数。因此,秤的分辨率对于这种情况是不够的。您能否确认您在其他操作系统或一般情况下观察到相同情况?有没有办法让VisualVM在显示CPU使用率时只考虑关联分配的核心?
我们希望将JConsole/JVisualVM的一些功能内部化,并从正在运行的应用程序中收集有关cpu利用率和内存消耗的数据。原因是,安全约束阻止我们在生产系统上向外部开放jmx端口。所需的大部分数据都可以通过MXBeans进行监控,但是,用于垃圾收集的cputime仍然让我们望而却步。通过GarbageCollectorMXBean监控gc-time没有用,因为它只提供并行工作收集器的walltime。我假设可以使用ThreadMXBean来确定所有gc线程的cputime。我看不出有什么办法可以安全地识别这些线程。有人知道JVisualVM是如何计算这个数字的吗?
我对获取给定JNIblock的CPU利用率有疑问。我正在底层C++JNInative方法中进行一些密集的CPU计算。我正在优化此计算并希望根据不同的输入对其进行基准测试。我需要一些关于如何衡量这一点的指导。到目前为止,我考虑过的替代方案是使用JMXThreadMXBean测量调用JNI方法的当前线程的系统CPU使用率。但是,我不确定JNI代码是否在调用线程上下文中执行。当线程产生更多线程时会发生什么?使用JMXOperatingSystemMXBean获取整个JVM的CPU使用率。理想情况下,这不是我想要的,因为JVM中的并行执行可能会调整基准测试。使用getrusage(..)进行外