Tomcat的JVM调优实战
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Tomcat的JVM调优实战相关的知识,希望对你有一定的参考价值。
一些调优点在上篇日志中已写到,在此不做说明
直接使用Jmeter进行调优测试吞吐量
Code
package cn;
import java.io.IOException;
import java.util.Map;
import java.util.WeakHashMap;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.User;
@WebServlet("/TestLogin")
public class TestLogin extends HttpServlet {
private static final long serialVersionUID = 1L;
private Map<User,byte[]> userdata = new WeakHashMap<User,byte[]>();
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
User user = new User();
user.setId(1);
user.setName("renlu");
user.setPwd("123");
userdata.put(user,new byte[1024]);
System.out.println("Hello bf ");
request.getRequestDispatcher("success.jsp").forward(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doGet(request, response);
}
}
实体
测试环境apache-tomcat-7.0.67,java version "1.8.0_60",apache-jmeter-2.13,每次吞吐量都测试3次,取中间的值
测试线程数10,线程组200
默认未调优前的吞吐量
吞吐量: 317
package com;
public class User {
private int id;
private String name;
private String pwd;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPwd() {
return pwd;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
}
测试线程数10,线程组200
默认未调优前的吞吐量
吞吐量: 317
调优一:
吞吐量 508
调优二:
新生代并行回收器,这是一个关注吞吐量的收集器,可以尽量减少GC的时间
老年代也使用并行回收收集器。
吞吐量 681
调优测试三:
使用-XX:+UseConcMarkSweepGC
总结:
JVM调优的过程有:确定堆内存大小(-Xmx -Xms)、合理分配新生代和老年代(-XX:NewRatio、-Xmn、-XX:SurvivorRatio),确定永久区的大小(-XX:Permsize、-XX:MaxPermSize)、选择垃圾收集器、对垃圾收集器进行合理的设置.当然还有禁用显示GC、禁用类元数据回收、禁用类验证等。可以根据自己的实际情况进行调优。
以上是关于Tomcat的JVM调优实战的主要内容,如果未能解决你的问题,请参考以下文章