96SEO 2026-02-19 20:13 12
方法2、确定应用程序类型3、加载所有的初始化器4、加载所有的监听器5、设置程序运行的主类6、开启计时器7、将

true8、获取并启用监听器9、设置应用程序参数10、准备环境变量11、忽略
信息13、创建应用程序的上下文14、实例化异常报告器15、准备上下文环境15.1、实例化单例的
生成器15.2、执行初始化方法15.3、将启动参数注册到容器中
17、刷新上下文后置处理18、结束计时器19、发布上下文准备就绪事件20、执行自定义的
存储起来然后再将不是抽象的、单例的、非懒加载的类进行实例化然后存放到
ApplicationEnvironmentPreparedEvent环境事件做一些绑定后返回
beanNameGeneratorbean、resourceLoader加载器就将其注入到上下文中调用初始化的切面发布
ApplicationContextInitializedEvent上下文初始化时间。
SpringApplicationRunListeners
的启动过程还是挺多的下面我们结合源码详细分析讲解启动过程中的步骤。
org.springframework.boot.SpringApplication;
org.springframework.boot.autoconfigure.SpringBootApplication;SpringBootApplication
启动应用SpringApplication.run(SpringbootDemoApplication.class,
AnnotationConfigApplicationContext
WebApplicationType.deduceFromClasspath();
SpringApplication(ResourceLoader
resourceLoader;Assert.notNull(primarySources,
LinkedHashSet(Arrays.asList(primarySources));this.webApplicationType
WebApplicationType.deduceFromClasspath();setInitializers((Collection)
getSpringFactoriesInstances(ApplicationContextInitializer.class));setListeners((Collection)
getSpringFactoriesInstances(ApplicationListener.class));this.mainApplicationClass
org.springframework.context.ApplicationContextInitializer
MyApplicationContextInitializer.java
org.springframework.context.ApplicationContextInitializer;
org.springframework.context.ConfigurableApplicationContext;/***
MyApplicationContextInitializer
initialize(ConfigurableApplicationContext
{System.out.println(MyApplicationContextInitializer.initialize());}
org.springframework.context.ApplicationContextInitializer\
com.demo.application.MyApplicationContextInitializer启动
后就可以看到控制台打印的内容了在这里我们可以很直观地看到它地执行顺序是在打印
方法是非静态的是需要实例化后才可以调用的进来后首先会开启计时器这个计时器有什么作用呢顾名思义就是用来记录
true表示运行在服务器端在没有显示和鼠标键盘的模式下照样可以工作模拟输入输出设备功能。
想干什么呢其实是像设置该应用程序即使没有检测到显示器也允许其启动对于服务器来说是不需要显示器的所以要这样设置。
{System.setProperty(SYSTEM_PROPERTY_JAVA_AWT_HEADLESS,System.getProperty(SYSTEM_PROPERTY_JAVA_AWT_HEADLESS,
Boolean.toString(this.headless)));
DefaultApplicationArguments(String...
configureIgnoreBeanInfo(ConfigurableEnvironment
(System.getProperty(CachedIntrospectionResults.IGNORE_BEANINFO_PROPERTY_NAME)
environment.getProperty(spring.beaninfo.ignore,
Boolean.TRUE);System.setProperty(CachedIntrospectionResults.IGNORE_BEANINFO_PROPERTY_NAME,
的信息解析通常不再需要而且会对性能产生负面影响。
因此大多数形况下无需关注或更改该配置。
需要注意的是这个异常报告器只会捕获启动过程抛出的异常如果是在启动完成后在用户请求时报错异常捕获器不会捕获请求中出现的异常。
org.springframework.boot.SpringBootExceptionReporter;
org.springframework.context.ConfigurableApplicationContext;/***
必须要有一个有参构造函数否则启动会报错MyExceptionReporter(ConfigurableApplicationContext
{System.out.println(MyExceptionReporter.reportException()
called.);failure.printStackTrace();//
org.springframework.boot.SpringBootExceptionReporter\
com.demo.application.MyExceptionReporter然后我们在
中把端口设置为一个很大的值端口的最大值为65535我们设置为5个8
postProcessApplicationContext(context);
初始化方法有哪些呢还记得第3步里面加载的初始化器吗其实是执行第3步加载出来的所有初始化器实现了
这里将启动参数以单例的模式注册到容器中是为了以后方便拿来使用参数的
{//为容器初始化做准备prepareRefresh();//
解析xml和注解ConfigurableListableBeanFactory
给BeanFacory设置属性值以及添加一些处理器即准备Spring的上下文环境prepareBeanFactory(beanFactory);try
由子类实现对BeanFacoty的一些后置处理postProcessBeanFactory(beanFactory);/**
BeanDefinitionRegistryPostProcessor*
完成对这两个接口的调用*/invokeBeanFactoryPostProcessors(beanFactory);/**
把实现了BeanPostProcessor接口的类实例化并且加入到BeanFactory中*/registerBeanPostProcessors(beanFactory);/**
国际化*/initMessageSource();//初始化事件管理类initApplicationEventMulticaster();//这个方法着重理解模板设计模式因为在springboot中这个方法是用来做内嵌tomcat启动的onRefresh();/**
往事件管理类中注册事件类*/registerListeners();/**
5、Aop的入口*/finishBeanFactoryInitialization(beanFactory);//
finishBeanFactoryInitialization
PostConstruct、PreDestroy、Resource、Autowired、Value
finishBeanFactoryInitialization(ConfigurableListableBeanFactory
singletons.beanFactory.preInstantiateSingletons();
{logger.trace(Pre-instantiating
xml解析时讲过把所有beanName都缓存到beanDefinitionNames了ListString
ArrayList(this.beanDefinitionNames);//
把父BeanDefinition里面的属性拿到子BeanDefinition中RootBeanDefinition
getMergedLocalBeanDefinition(beanName);//如果不是抽象的单例的非懒加载的就实例化if
{//判断bean是否实现了FactoryBean接口这里可以不看if
AccessController.doPrivileged((PrivilegedActionBoolean)((SmartFactoryBean?)
factory)::isEagerInit,getAccessControlContext());}else
{//主要从这里进入看看实例化过程getBean(beanName);}}}
}其他详细内容可以参考下这位大佬的文章Spring的Bean实例化原理这一次彻底搞懂了
方法是启动后的一些处理留给用户扩展使用目前这个方法里面是空的。
afterRefresh(ConfigurableApplicationContext
接下来我们验证一把为了一次性验证全我们把这2种方式都放在同一个类里面。
org.springframework.boot.ApplicationArguments;
org.springframework.boot.ApplicationRunner;
org.springframework.boot.CommandLineRunner;
org.springframework.stereotype.Component;/***
1.SpringBoot启动过程https://blog.csdn.net/qq_42259971/article/details/127151316
2.Spring的Bean实例化原理这一次彻底搞懂了https://zhuanlan.zhihu.com/p/198087901
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback