为了账号安全,请及时绑定邮箱和手机立即绑定

JVM 线程创建速度非常慢

JVM 线程创建速度非常慢

莫回无 2021-10-17 10:58:13
我们的其中一台主机存在 JVM 性能问题。主机是 16 个 CPU 内核,16Gb RAM,Windows Server 2012 是主机操作系统。JVM 1.8 131,Xmx 10Gb,但2-3Gb 正常运行就够了,消耗很少上升。该应用程序使用所有内核,但 CPU 使用率非常低 - 最高 15%。GC 活动低。在其他主机上运行具有相同配置的相同应用程序没有性能问题,并且可以根据需要轻松消耗更多 2-3Gb RAM 和 CPU。但是在这个特定的主机上,当一些负载开始时,应用程序变得几乎没有响应。我们已经预定义了几个线程池的核心大小,当应用程序开始通过创建新线程来增加池时 - 它几乎卡住了。线程转储看起来很奇怪。大量使用 java.lang.Thread.setPriority0() 运行的线程执行了很长时间。喜欢:"Thread-14592" #676532 daemon prio=3 os_prio=0 tid=0x0000000026852000 nid=0x15a0 runnable [0x000000003737e000]       java.lang.Thread.State: RUNNABLE    at java.lang.Thread.setPriority0(Native Method)    at java.lang.Thread.setPriority(Unknown Source)    at java.lang.Thread.init(Unknown Source)    at java.lang.Thread.init(Unknown Source)    at java.lang.Thread.<init>(Unknown Source)    at java.util.concurrent.Executors$DefaultThreadFactory.newThread(Unknown Source)    at com.util.NamedThreadFactory.newThread(NamedThreadFactory.java:38)at java.util.concurrent.ThreadPoolExecutor$Worker.<init>(Unknown Source)    at java.util.concurrent.ThreadPoolExecutor.addWorker(Unknown Source)    at java.util.concurrent.ThreadPoolExecutor.execute(Unknown Source)    at java.util.concurrent.AbstractExecutorService.submit(Unknown Source)...该setPriority0()可几分钟的运行,因此应用程序的性能是该主机上的可怕。我们尝试设置 -XX:-UseThreadPriorities 但结果相同。有人能给我们一个线索,我们应该看看什么才能找到所描述行为的原因吗?
查看完整描述

1 回答

?
慕慕森

TA贡献1856条经验 获得超17个赞

它确实是一种防病毒软件。

不知道它的具体设置是什么,但是当关闭防病毒软件时,该应用程序会恢复到普通的 fast'n'furious 流程。


查看完整回答
反对 回复 2021-10-17
  • 1 回答
  • 0 关注
  • 234 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信