【发布时间】:2018-09-16 17:30:36
【问题描述】:
我刚刚安装了一台新服务器(Xeon E5-2630 v4,256GB RAM、Ubuntu 18、Tomcat 8、Java 8)来替换当前使用了 4 年的服务器(i5-2400、8GB RAM、Ubuntu 14、Tomcat 7,Java 7) 并且在测试期间发现在一个大的测试页面上,新服务器比旧服务器慢 10 倍以上。稍后进行一些挖掘,在我的开发机器(Java 8)上运行 Tomcat 8(安装了 apt-get)也是如此,但在运行 Spring Tool Suite 捆绑的 tc 服务器(也基于 Tomcat8!)时不是这样!
示例页面上的测试结果。所有 4 个实例上的相同 spring 应用程序战争文件。在本地运行,应用程序在控制器中记录页面生成时间,这在所有 4 上大致相同,因此问题必须在 jsp 生成中或(很可能是 imo)在连接中:
time wget http://localhost:8080/proteus/testpage
- 旧服务器:4,643,048 字节 5.88M/s in 0.8s
- 新服务器:4.43M 276KB/s in 16s
- Dev Machine tcServer(基于 Tomcat8):4.43M 4.24MB/s in 1.0s
- 开发机器 Tomcat 8:4.43M 318KB/s in 14s
对于同一台机器上的巨大差异,我一定是在连接设置/配置中遗漏了一些非常基本的东西,但在过去 2 天的大部分时间里,我一直在进行故障排除,但没有取得任何进展。
如果有人对看什么有任何建议,我将不胜感激。在开发机器上工作似乎最简单,所以我从那里附加了一些信息。
问候。
堆在 tcServer 上设置为 -Xmx768m,在 Tomcat 8 上设置为 -Xmx2048m。
tcServer 版本信息:
Using CATALINA_BASE: /home/mjames/sts-bundle/pivotal-tc-server-developer-3.1.5.RELEASE/tomcat-8.0.36.A.RELEASE
Using CATALINA_HOME: /home/mjames/sts-bundle/pivotal-tc-server-developer-3.1.5.RELEASE/tomcat-8.0.36.A.RELEASE
Using CATALINA_TMPDIR: /home/mjames/sts-bundle/pivotal-tc-server-developer-3.1.5.RELEASE/tomcat-8.0.36.A.RELEASE/temp
Using JRE_HOME: /usr
Using CLASSPATH: /home/mjames/sts-bundle/pivotal-tc-server-developer-3.1.5.RELEASE/tomcat-8.0.36.A.RELEASE/bin/bootstrap.jar:/home/mjames/sts-bundle/pivotal-tc-server-developer-3.1.5.RELEASE/tomcat-8.0.36.A.RELEASE/bin/tomcat-juli.jar
Server version: Pivotal tc Runtime 3.1.5.RELEASE/8.0.36.A.RELEASE
Server built: Jun 29 2016 20:36:49 UTC
Server number: 8.0.36.0
OS Name: Linux
OS Version: 4.4.0-116-generic
Architecture: amd64
JVM Version: 1.8.0_162-8u162-b12-0ubuntu0.16.04.2-b12
JVM Vendor: Oracle Corporation
tomcat 8 版本信息:
Using CATALINA_BASE: /usr/share/tomcat8
Using CATALINA_HOME: /usr/share/tomcat8
Using CATALINA_TMPDIR: /usr/share/tomcat8/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/share/tomcat8/bin/bootstrap.jar:/usr/share/tomcat8/bin/tomcat-juli.jar
Server version: Apache Tomcat/8.0.32 (Ubuntu)
Server built: Sep 27 2017 21:23:18 UTC
Server number: 8.0.32.0
OS Name: Linux
OS Version: 4.4.0-116-generic
Architecture: amd64
JVM Version: 1.8.0_162-8u162-b12-0ubuntu0.16.04.2-b12
JVM Vendor: Oracle Corporation
server.xml 中的连接器(两者相同,将它们简化为基础)
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000"
URIEncoding="UTF-8" redirectPort="8443" />
【问题讨论】:
-
分析您的 Java 应用程序。飞行记录器应该可以。
-
每一个的启动时间呢?在 catalina.out 中检查。看看糟糕的性能是否仅在消费服务时很有趣。