Servlet 初始化
Listener > Filter > Servlet,Listener的初始化最早,Filter次之。他俩的初始化都是在容器启动完成之前初始化的。Servlet没有初始化,原因是没有匹配的请求进来。如果想要servlet自动初始化,需要在指定的servlet中配置参数,没有此标签,默认启动时servlet不进行初始化。
初始化的顺序跟Listener、Filter、Servlet在web.xml中的顺序无关,而多个Filter或多个Servlet的时候,谁的mapping在前面,谁先初始化。
如果web.xml中配置了<context-param>,初始化顺序:context-param > Listener > Filter > Servlet
spring Bean 初始化
可以看出在tomcat 容器启动后
再次启动 linster->bean->spring 上下文
WebServerInitializedEvent &ApplicationRunner 用法
WebServerInitializedEvent
用于监听web 容器启动,就可以获取启动web 容器的一些基本信息;
在springboot 容器中通过 @EventListener(WebServerInitializedEvent.class), EventListener 获取监听web 启动事件,获取容器的一些基本信息,如名称、端口号
@EventListener(WebServerInitializedEvent.class)
public void onWebServerReady(WebServerInitializedEvent event) {
System.out.println("当前 WebServer 实现类为:" + event.getWebServer().getClass().getName());
}
ApplicationRunner
用于 用于在springboot 容器启动后进行回调,用于spring 容器启动后做一些操作
示例
application.properties
app.name=yaoyuan2
app.dept.id=1
MyConfig.java
import lombok.AllArgsConstructor;
import lombok.Data;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class MyConfig {
@Value("${app.name}")
public String name;
@Value("${app.dept.id}")
public String id;
@Bean
public Dept getDept() {
return new Dept(id);
}
@Bean
public User getUser() {
return new User(name,getDept());
}
}
@Data
@AllArgsConstructor
class User {
private String name;
private Dept dept;
}
@Data
@AllArgsConstructor
class Dept {
private String id;
}
初始化:
@EventListener(WebServerInitializedEvent.class)
public void onWebServerReady(WebServerInitializedEvent event) {
System.out.println("1.当前WebServer实现类为:"+event.getWebServer().getClass().getName());
Object obj = event.getApplicationContext().getBean(User.class);
System.out.println("获取user对象:"+obj);
}
/**
* 在spring boot应用启动后回调
* @param context
* @return
*/
@Bean
public ApplicationRunner runner(WebServerApplicationContext context) {
return args -> {
System.out.println("2.当前WebServer实现类为:"+context.getWebServer().getClass().getName());
Object obj = context.getBean(User.class);
System.out.println("获取user对象:"+obj);
};
}
输出
2019-10-19 19:33:11.130 INFO 2312 --- [ main] o.s.b.web.embedded.netty.NettyWebServer : Netty started on port(s): 8080
1.当前WebServer实现类为:org.springframework.boot.web.embedded.netty.NettyWebServer
获取user对象:User(name=yaoyuan2, dept=Dept(id=1))
2019-10-19 19:33:11.135 INFO 2312 --- [ main] c.e.s.App : Started App in 4.57 seconds (JVM running for 5.33)
2.当前WebServer实现类为:org.springframework.boot.web.embedded.netty.NettyWebServer
获取user对象:User(name=yaoyuan2, dept=Dept(id=1))