【新手记录】servlet的初始化init方法什么时候被调用?

阅读更多

前几天跟几个同学聊到这个,

我一直认为的是说:在容器启动的时候,就会加载web.xml然后将里面的servlet进行初始化加载,

然后调用其init方法。

 

可是一个同学说:是在第一个请求到来的时候才调用init方法。

 

另外一个同学说:跟配置的servlet的

1

这个参数有关。

 

我当时想了下说,会不会load-on-startup配置为0就是默认跟容器一起初始化,否则就是第一次请求的时候初始化。

 

带着这个疑问做了下简单的servlet的测试。。

 

public class SimpleDispatherServlet extends HttpServlet

 

public void init() throws ServletException {
		System.out.println("SimpleDispatherServlet init");
}
 

web.xml中的配置

 


        simpleDispatherServlet
        simpleDispatherServlet
        SimpleDispatherServlet
        2

 

看到控制台中打印出来了

 

[INFO] Starting jetty 7.0.1.v20091125 ...
2010-05-15 21:14:31.855:INFO::jetty-7.0.1.v20091125
2010-05-15 21:14:32.155:INFO::No Transaction manager found - if your webapp requ
ires one, please configure one.
SimpleDispatherServlet init
。。。。

 

事后,我又将load-on-startup进行了参数更改,还是一样init方法还是跟容器启动的时候一起调用。不存在影响的问题。

 

看来load-on-startup跟这没关系的。想想还是我之前理解的是正确的,servlet的初始化方法一般都包括读取配置文件等很多事情,如果放在第一次请求的时候才发现问题,才进行加载,也有些太不靠谱了。

 

ok,记录一下!~

 

===============================================

 

刚开始做了这个实验觉得不靠谱,又去查询了servlet的API,具体写在下一篇博客:

 

http://guoliangqi.iteye.com/blog/670710

 

API里面很清楚的说明了oad-on-startup对servlet初始化的影响。

 

 

 

你可能感兴趣的:(Servlet,log4j,Web,XML,Blog)