start办法里的源码
public void start() throws IllegalStateException { this.start(""); } public void start(String taskName) throws IllegalStateException { if (this.currentTaskName != null) { throw new IllegalStateException("Can't start StopWatch: it's already running"); } else { //给stopWatch对象保留一些信息 this.currentTaskName = taskName;//当前任务的名字 this.startTimeNanos = System.nanoTime();//以后的工夫 }
createBootstrapContext创立疏导上下文
private DefaultBootstrapContext createBootstrapContext() { //创立默认的疏导上下文对象 //当前就会给外面保留很多信息 DefaultBootstrapContext bootstrapContext = new DefaultBootstrapContext();//遍历所有之前的获取到的bootstrappers,调用每一个bootstrappers的intitialize() 来实现对疏导启动器上下文环境设置 this.bootstrappers.forEach((initializer) -> initializer.intitialize(bootstrapContext)); return bootstrapContext;//null }=============================================================public interface Bootstrapper { /** * Initialize the given {@link BootstrapRegistry} with any required registrations. * @param registry the registry to initialize *///传入疏导注册工厂//这个工厂外面能够给他退出一些以后上下文的一些疏导环境信息 void intitialize(BootstrapRegistry registry);}
让以后利用进入headless模式
private void configureHeadlessProperty() { System.setProperty(SYSTEM_PROPERTY_JAVA_AWT_HEADLESS, System.getProperty(SYSTEM_PROPERTY_JAVA_AWT_HEADLESS, Boolean.toString(this.headless))); }
获取所有RunListener(运行监听器)
所谓的监听器就是监听到以后我的项目的状态
private SpringApplicationRunListeners getRunListeners(String[] args) { Class<?>[] types = new Class<?>[] { SpringApplication.class, String[].class };//new SpringApplicationRunListeners:相当于把找到的Listener保留到SpringApplicationRunListener; return new SpringApplicationRunListeners(logger,//getSpringFactoriesInstances: 去spring.factories找SpringApplicationRunListener getSpringFactoriesInstances(SpringApplicationRunListener.class, types, this, args), this.applicationStartup); }=====================================================SpringApplicationRunListeners(Log log, Collection<? extends SpringApplicationRunListener> listeners, ApplicationStartup applicationStartup) { this.log = log; this.listeners = new ArrayList<>(listeners); this.applicationStartup = applicationStartup; }List<SpringApplicationRunListener> listeners;
starting():
遍历所有的SpringApplicationRunListener
调用 starting
办法;相当于告诉所有感兴趣零碎正在启动过程的人,我的项目正在 starting。(即通知我这个我的项目正在启动)
void starting(ConfigurableBootstrapContext bootstrapContext, Class<?> mainApplicationClass) { doWithListeners("spring.boot.application.starting", (listener) -> listener.starting(bootstrapContext), (step) -> { if (mainApplicationClass != null) { step.tag("mainApplicationClass", mainApplicationClass.getName()); } }); }=========================================进入doWithListeners办法:private void doWithListeners(String stepName, Consumer<SpringApplicationRunListener> listenerAction, Consumer<StartupStep> stepAction) { StartupStep step = this.applicationStartup.start(stepName); //遍历所有的listeners,当初进行到哪一步了,相当于一个事件信息 this.listeners.forEach(listenerAction); if (stepAction != null) { stepAction.accept(step); } step.end(); }================================进入this.listeners.forEach(listenerAction):void starting(ConfigurableBootstrapContext bootstrapContext, Class<?> mainApplicationClass) {//遍历所有的SpringApplicationRunListener调用starting办法 doWithListeners("spring.boot.application.starting", (listener) -> listener.starting(bootstrapContext), (step) -> { if (mainApplicationClass != null) { step.tag("mainApplicationClass", mainApplicationClass.getName()); } }); }