问题
DispatcherServlet
的懒加载会导致在用户在进行第一次请求的时候会比正常慢很多,如果这个时候大量请求同时过来,那么阻塞和cpu的暴增就会显而易见。
背景
在回顾SpringMvc对servlet的增强的过程中,突然发现DispatcherServlet
是懒加载的,而这份懒加载的来源竟然是tomcat。
其实对于现在的大多数人来说,可能不太清楚为什么tomcat要实行servlet的懒加载,但是如果回到springmvc和struts未诞生之前,这个问题其实很好回答。
因为在以servlet和jsp为主的年代,在tomcat中会存在大量的servlet,这个时候懒加载就很有必要了。
但是对SpringMvc来说,其实只向tomcat注册了一个servlet,这个时候懒加载的意义其实不太大了(请不要极端)。
解决方案:
在配置文件中配置spring.mvc.servlet.load-on-startup=1
即可,1 这个值不是固定的只要比0大就行,是用来对tomcat的Wrapper
进行排序的。
具体细节:
在SpringMvc的DispatcherServlet
向tomcat进行servlet注册时,会将spring.mvc.servlet.load-on-startup
的值写入到Wrapper的loadOnStartup
属性中,然后tomcat执行下列流程就能初始化servlet了。
-
排序要初始化servlet的Wrapper
-
按顺序进行Wrapper的servlet初始化
-
调用servlet的init方法完成servlet的初始化