java - 尝试了解 Servlet 调用的计数

标签 java tomcat servlets

我正在使用 Siege 进行一些负载测试和 Apache benchmarking tool 。我计算了对 ServletprocessRequest 内的 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.11jdk1.7.0_02

最佳答案

您必须使用volatile关键字,因为 countcount2 被很多线程使用

 static volatile int count=0;
 static volatile int count2=0;

关于java - 尝试了解 Servlet 调用的计数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9532559/

相关文章:

session - 如何准确有效地衡量HttpSession大小

java - 即使找到两个库,Spark 也会出现日志记录错误

java - 桌面应用程序的 UI

JavaBridge 不打开 php(无法连接到服务器)

jsp - Tomcat 请求处理实例的优点/缺点是什么?

java - HttpURLConnection 和浏览器连接之间的区别

Spring将请求范围的bean提升到子线程(HttpServletRequest)

java - Tapestry Hibernate session 超出 ExecutorService 固定线程池后关闭

java - 从作业中停止 ScheduledExecutorService 中的 Runnable 作业

tomcat - 无法在命令行中启动/关闭tomcat