我正在使用 Siege 进行一些负载测试和 Apache benchmarking tool 。我计算了对 Servlet
和 processRequest
内的 runAlgo
方法的调用次数。
我使用这段代码:
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(name = "Servlet", urlPatterns = {"/test"})
public class Servlet extends HttpServlet {
static int count=0;
static int count2=0;
/**
* Processes requests for both HTTP <code>GET</code> and <code>POST</code> methods.
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("Process request : "+count2++);
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {
// TODO output your page here
out.println("<html>");
out.println("<head>");
out.println("<title>Result</title>");
out.println("</head>");
out.println("<body>");
out.println("<h1>Result : " + runAlgo() + "</h1>");
out.println("</body>");
out.println("</html>");
} finally {
out.close();
}
}
private ArrayList<String> runAlgo() {
System.out.println("algo : "+count++);
//the algo code
}
}
我有两个问题:
首先,runAlgo()
方法被调用的次数比processRequest
更频繁,这看起来很奇怪,因为runAlgo
只在这里被调用!
然后另一个问题涉及基准测试,如果我发送例如 200 个请求,我在日志中从来没有计数为 200,但工具说所有事务都已成功(服务器响应返回码 < 400)
你对这种行为有什么解释吗?
我使用apache-tomcat-7.0.11
和jdk1.7.0_02
最佳答案
您必须使用volatile关键字,因为 count 和 count2 被很多线程使用
static volatile int count=0;
static volatile int count2=0;
关于java - 尝试了解 Servlet 调用的计数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9532559/