servlet被调用的次数随着获取的请求数量而增加

时间:2014-03-13 15:58:21

标签: java jsp tomcat servlets

我有以下代码,

public class HttpAdapter extends HttpServlet {
    private static final long serialVersionUID = 1L;
    static Logger l = Logger.getLogger(HttpAdapter.class.getName());

    public HttpAdapter() {
        super();     
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        try{
            Layout ll = new SimpleLayout();
            Appender a = new FileAppender();
            a = new FileAppender(ll,"C:\\Users\\Vasanth\\Desktop\\JDlogs\\my.txt");
            l.info(request.getRemoteHost());
            l.addAppender(a); 

            String loc = DTO.findMyLocation();      
            l.info(loc);

            l.info(this.getClass()+" >>>>>>>>>>>>>>task complete");
            l.info(request.getRemoteHost());

        }catch(Exception e){
            e.printStackTrace();        
        }finally{
            getServletContext().getRequestDispatcher("/JSP/done.jsp").forward(request, response);
        }

    }
    //F:\\home\\WorkSpace\\Jdfront1\\webapps\\JSP\\

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    }
}

这是不寻常的事情:每当我从浏览器通过看起来像的jsp页面向这个servlet发出请求时,

<!DOCTYPE html>
<html>
 <head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>jdHome</title>
</head>
<body>
<header>hello!!</header>
<section>
<form action="http://192.168.1.101:90/Jdfront1/hello">
<label>Topic :</label><input type="text" name="topic"/><br>
<label>Number of pages :</label><input type="text" name="Nopages"/><br>
<label>URL :</label><input type="text" name="link"/><br>
<label>isRange :</label><input type="text" name="range"/><br>
<input type="submit">

</form>
</section>

第一次发出请求时,它运行正常并且日志也只进行一次, 但是当我从jsp向同一个servlet发出第二个请求时,整个程序运行两次。日志来了两次,就像我有一个System.out.println("hello")一样,它打印'hello'两次。当我提出第3个请求时,它打印3次然后继续!我曾经在调度员身上找不到我想要转发的东西吗?我到处尝试过,没有类似的问题,甚至接近这个问题都在任何地方报道。

1 个答案:

答案 0 :(得分:6)

为什么要在doGet()方法中配置记录器?

正如您所指出的,此方法将在每个请求上执行。

但是,您可能只想配置您的记录器,并且只需一次 。这个逻辑的一个更好的地方是Servlet的init方法(这个逻辑的最佳位置是外部XML或属性文件)。

您看到日志行的多个副本的原因是,当您收到第四个请求时,您已向记录器添加了四个appender。记录器框架不知道这些appender是彼此重复的,并将日志消息发送给每个。