Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/378.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 为什么在Tomcat下运行的应用程序只使用了一半的可用CPU?_Java_Performance_Tomcat_Windows Server 2008 - Fatal编程技术网

Java 为什么在Tomcat下运行的应用程序只使用了一半的可用CPU?

Java 为什么在Tomcat下运行的应用程序只使用了一半的可用CPU?,java,performance,tomcat,windows-server-2008,Java,Performance,Tomcat,Windows Server 2008,我有一个第三方Java应用程序,在Win2008 R2 64位下运行在Tomcat下。它是一个多线程应用程序,通过SOAP服务公开其API 当我查看Task Manager性能选项卡时,它似乎只使用了8个内核中的4个,而不管我对它施加了多少负载。应用程序供应商断断续续地发誓,他们没有做任何会影响CPU使用率的事情(而且他们也没有看到这一点) 我已经做了以下工作: 已检查tomcat6.exe的关联性-它使用所有处理器 检查以确保Java服务实际上正在接收所有请求—确实如此 查看了tomcat目

我有一个第三方Java应用程序,在Win2008 R2 64位下运行在Tomcat下。它是一个多线程应用程序,通过SOAP服务公开其API

当我查看Task Manager性能选项卡时,它似乎只使用了8个内核中的4个,而不管我对它施加了多少负载。应用程序供应商断断续续地发誓,他们没有做任何会影响CPU使用率的事情(而且他们也没有看到这一点)

我已经做了以下工作:

  • 已检查tomcat6.exe的关联性-它使用所有处理器
  • 检查以确保Java服务实际上正在接收所有请求—确实如此
  • 查看了tomcat目录中的每个.conf文件,但没有看到任何相关的内容(这也是我第一次接触tomcat,所以我真的不知道我在寻找什么)
  • 在两台不同的服务器上用Java1.5和1.6进行了测试,结果相同
一些硬件如下所示: 2个Xeon E5606@2.13 Ghz处理器,每个处理器有4个内核。 72 GB的RAM—分配给Tomcat的24 GB内存


为什么Java应用程序只使用了一半的核心?

尝试在同一JVM中运行此JSP,以测试是否使用了所有核心:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<%

class ThreadLoad implements Runnable {
    public void run() {
        long result = 0;
        // increase the amount of loops until sufficient load
        for (long dummy = 0; dummy < 100000000; dummy++) {
            if (dummy % 2 == 0)
                result += dummy;
            else
                result -= dummy;
        }
    }
}

int cpus = Runtime.getRuntime().availableProcessors();
Thread[] threads = new Thread[cpus];

for (int i = 0; i < cpus; i++) {
    threads[i] = new Thread(new ThreadLoad());
    threads[i].start();
}

for (int i = 0; i < cpus; i++) {
    threads[i].join();
}

response.getWriter().println("Done");

%>
</body>
</html>

在此处插入标题

我可以想象你已经放弃了磁盘I/O上有块吗?@Luis我不认为有块,因为所有的工作都是在内存中的数据集上完成的,但我发现这几乎是一样的,说明正在使用的日志框架正在减慢一切。如果是这样,我将以dup的身份结束这个问题。听起来Tomcat只使用了一个物理处理器,但很难说为什么。看看这是否有帮助:您是否尝试在同一个JVM中运行一个虚拟应用程序,尝试完全加载与您拥有的内核数量相同的线程?@Luis Nope,这不是I/O。我得到以下错误:
类型为ThreadLoad的run()方法必须覆盖一个超类方法
实际上尝试将其添加到顶部
,删除@Override成功了。谢谢Tomcat很好——它绑定了所有CPU。供应商的软件一定有问题。看起来是这样。祝卖主好运。