SpringBoot啟動流程是什麼
SpringBoot啟動過程簡介
SpringBoot應用程式的啟動過程可以分為以下步驟:
載入應用程式上下文
掃描應用程式中的所有元件
自動配置應用程式環境
啟動嵌入式網路伺服器
#載入應用程式上下文
一個包含SpringBoot 應用程式所有元件的容器就是它的上下文。在啟動過程中,SpringBoot 會載入並初始化這個容器。
這個步驟的原始碼在SpringApplication
類別中。具體來說,SpringApplication
類別的run
#方法是這個過程的入口點。在這個方法中,Spring Boot會透過呼叫createApplicationContext
方法來建立應用程式上下文。
下面是createApplicationContext
方法的原始程式碼:
protected ConfigurableApplicationContext createApplicationContext() { Class<?> contextClass = this.applicationContextClass; if (contextClass == null) { try { switch (this.webApplicationType) { case SERVLET: contextClass = Class.forName(DEFAULT_SERVLET_WEB_CONTEXT_CLASS); break; case REACTIVE: contextClass = Class.forName(DEFAULT_REACTIVE_WEB_CONTEXT_CLASS); break; default: contextClass = Class.forName(DEFAULT_CONTEXT_CLASS); } } catch (ClassNotFoundException ex) { throw new IllegalStateException( "Unable to create a default ApplicationContext, " + "please specify an ApplicationContextClass", ex); } } return (ConfigurableApplicationContext) BeanUtils.instantiateClass(contextClass); }
在這個方法中,SpringBoot 會根據應用程式類型(Servlet或Reactive)選擇合適的上下文類別。接著,使用 Java 反射機制來實例化該類別並傳回一個可配置的應用程式上下文物件。
掃描應用程式中的所有元件
在上一個步驟中,SpringBoot創建了應用程式上下文。在此階段,SpringBoot會掃描應用程式中的所有元件並將它們註冊到應用程式上下文中。
這個步驟的原始碼在SpringApplication
類別中的scan
方法中。具體來說,在這個方法中,SpringBoot 會建立一個SpringBootBeanDefinitionScanner
對象,並使用它來掃描應用程式中的所有元件。
下面是scan
方法的原始程式碼:
private void scan(String... basePackages) { if (ObjectUtils.isEmpty(basePackages)) { return; } ClassPathScanningCandidateComponentProvider scanner = new ClassPathScanningCandidateComponentProvider( this.includeFilters, this.excludeFilters, this.resourceLoader); scanner.setResourceLoader(this.resourceLoader); scanner.setEnvironment(this.environment); scanner.setIncludeAnnotationConfig(this.useAnnotatedConfig); scanner.addExcludeFilter(new AbstractTypeHierarchyTraversingFilter(false, false) { @Override protected boolean matchClassName(String className) { return getExcludeClassNames().contains(className); } }); for (String basePackage : basePackages) { scanner.findCandidateComponents(basePackage).forEach(this.componentDefinitions::add); } }
在這個方法中,SpringBoot 會建立一個ClassPathScanningCandidateComponentProvider
對象,並使用它來掃描應用程式中的所有元件。這個物件會掃描指定套件路徑下的所有類別,並將它們轉換為 Spring 的 Bean 定義。這些 Bean 定義將會註冊到應用程式上下文中。
自動配置應用程式環境
SpringBoot在前一步將應用程式中的所有元件註冊到應用程式上下文中。 SpringBoot會自動配置應用程式環境,其中包括資料來源、事務管理器和JPA配置。
這個步驟的原始碼在SpringApplication
類別中的configureEnvironment
方法中。在這個方法中,Spring Boot會建立一個SpringApplicationRunListeners
對象,並使用它來配置應用程式環境。
下面是configureEnvironment
方法的原始程式碼:
private void configureEnvironment(ConfigurableEnvironment environment, String[] args) { if (this.addCommandLineProperties) { ApplicationArguments applicationArguments = new DefaultApplicationArguments(args); environment.getPropertySources().addLast(new CommandLinePropertySource(applicationArguments)); } this.listeners.environmentPrepared(environment); if (this.logStartupInfo) { this.logStartupInfo(environment); } ConfigurationPropertySources.attach(environment); Binder.get(environment).bind(ConfigurationPropertyName.EMPTY, Bindable.ofInstance(this.sources)); if (!this.isCustomEnvironment) { EnvironmentConverter.configureEnvironment(environment, this.deduceEnvironmentClass()); } this.listeners.environmentPrepared(environment); }
在這個方法中,SpringBoot 會建立一個ApplicationArguments
對象,並將其轉換為一個命令列屬性來源。然後,它會呼叫listeners
中的environmentPrepared
方法來通知應用程式環境已經準備好了。隨後,SpringBoot 會綁定屬性來源到應用程式環境中,並呼叫listeners
中的environmentPrepared
方法來通知應用程式環境已經準備好了。
啟動嵌入式Web伺服器
在前一步驟中,SpringBoot已自動完成了應用程式環境的設定。在這一步驟,SpringBoot將啟動內嵌式Web伺服器,以便應用程式提供Web服務。
這個步驟的原始碼在SpringApplication
類別中的run
方法中。具體來說,在這個方法中,SpringBoot 會根據應用程式類型(Servlet或Reactive)選擇合適的嵌入式Web伺服器,並使用它來啟動應用程式。
下面是run
方法的原始程式碼:
public ConfigurableApplicationContext run(String... args) { StopWatch stopWatch = new StopWatch(); stopWatch.start(); ConfigurableApplicationContext context = null; Collection<SpringBootExceptionReporter> exceptionReporters = new ArrayList<>(); configureHeadlessProperty(); SpringApplicationRunListeners listeners = getRunListeners(args); listeners.starting(); try { ApplicationArguments applicationArguments = new DefaultApplicationArguments(args); ConfigurableEnvironment environment = prepareEnvironment(listeners, applicationArguments); configureIgnoreBeanInfo(environment); Banner printedBanner = printBanner(environment); context = createApplicationContext(); exceptionReporters = getSpringFactoriesInstances( SpringBootExceptionReporter.class, new Class[] { ConfigurableApplicationContext.class }, context); prepareContext(context, environment, listeners, applicationArguments, printedBanner); refreshContext(context); afterRefresh(context, applicationArguments); stopWatch.stop(); if (this.logStartupInfo) { new StartupInfoLogger(this.mainApplicationClass).logStarted(getApplicationLog(), stopWatch); } listeners.started(context); callRunners(context, applicationArguments); } catch (Throwable ex) { handleRunFailure(context, ex, exceptionReporters, listeners); throw new IllegalStateException(ex); } try { listeners.running(context); } catch (Throwable ex) { handleRunFailure(context, ex, exceptionReporters, null); throw new IllegalStateException(ex); } return context; }
在這個方法中,SpringBoot 會使用一個StopWatch
物件來計算應用程式啟動時間。然後,它會呼叫listeners
中的starting
方法來通知應用程式即將啟動。接著,SpringBoot 會準備應用程式環境,並使用它來建立應用程式上下文。隨後,SpringBoot 會呼叫listeners
中的started
方法來通知應用程式已經啟動。最後,SpringBoot 會呼叫callRunners
方法來運行所有的CommandLineRunner
和ApplicationRunner
元件。
以上是SpringBoot啟動流程是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Jasypt介紹Jasypt是一個java庫,它允許開發員以最少的努力為他/她的專案添加基本的加密功能,並且不需要對加密工作原理有深入的了解用於單向和雙向加密的高安全性、基於標準的加密技術。加密密碼,文本,數字,二進位檔案...適合整合到基於Spring的應用程式中,開放API,用於任何JCE提供者...添加如下依賴:com.github.ulisesbocchiojasypt-spring-boot-starter2. 1.1Jasypt好處保護我們的系統安全,即使程式碼洩露,也可以保證資料來源的

使用場景1、下單成功,30分鐘未支付。支付超時,自動取消訂單2、訂單簽收,簽收後7天未進行評估。訂單超時未評價,系統預設好評3、下單成功,商家5分鐘未接單,訂單取消4、配送超時,推播簡訊提醒…對於延時比較長的場景、即時性不高的場景,我們可以採用任務調度的方式定時輪詢處理。如:xxl-job今天我們採

一、Redis實現分散式鎖原理為什麼需要分散式鎖在聊分散式鎖之前,有必要先解釋一下,為什麼需要分散式鎖。與分散式鎖相對就的是單機鎖,我們在寫多執行緒程式時,避免同時操作一個共享變數產生資料問題,通常會使用一把鎖來互斥以保證共享變數的正確性,其使用範圍是在同一個進程中。如果換做是多個進程,需要同時操作一個共享資源,如何互斥?現在的業務應用通常是微服務架構,這也意味著一個應用會部署多個進程,多個進程如果需要修改MySQL中的同一行記錄,為了避免操作亂序導致髒數據,此時就需要引入分佈式鎖了。想要實現分

springboot讀取文件,打成jar包後訪問不到最新開發出現一種情況,springboot打成jar包後讀取不到文件,原因是打包之後,文件的虛擬路徑是無效的,只能通過流去讀取。文件在resources下publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input

在Springboot+Mybatis-plus不使用SQL語句進行多表添加操作我所遇到的問題準備工作在測試環境下模擬思維分解一下:創建出一個帶有參數的BrandDTO對像模擬對後台傳遞參數我所遇到的問題我們都知道,在我們使用Mybatis-plus中進行多表操作是極其困難的,如果你不使用Mybatis-plus-join這一類的工具,你只能去配置對應的Mapper.xml文件,配置又臭又長的ResultMap,然後再寫對應的sql語句,這種方法雖然看上去很麻煩,但具有很高的靈活性,可以讓我們

1.自訂RedisTemplate1.1、RedisAPI預設序列化機制基於API的Redis快取實作是使用RedisTemplate範本進行資料快取操作的,這裡開啟RedisTemplate類,查看該類別的源碼資訊publicclassRedisTemplateextendsRedisAccessorimplementsRedisOperations,BeanClassLoaderAware{//聲明了value的各種序列化方式,初始值為空@NullableprivateRedisSe

SpringBoot和SpringMVC都是Java開發中常用的框架,但它們之間有一些明顯的差異。本文將探究這兩個框架的特點和用途,並對它們的差異進行比較。首先,我們來了解一下SpringBoot。 SpringBoot是由Pivotal團隊開發的,它旨在簡化基於Spring框架的應用程式的建立和部署。它提供了一種快速、輕量級的方式來建立獨立的、可執行

本文來寫個詳細的例子來說下dubbo+nacos+Spring Boot開發實戰。本文不會講述太多的理論的知識,會寫一個最簡單的例子來說明dubbo如何與nacos整合,快速建構開發環境。
