Springboot熱部署實現(xiàn)原理及實例詳解
1.前言
在實際開發(fā)過程中,每次修改代碼就得將項目重啟,重新部署,對于一些大型應(yīng)用來說,重啟時間需要花費(fèi)大量的時間成本。對于一個后端開發(fā)者來說,重啟過程確實很難受啊。在 Java 開發(fā)領(lǐng)域,熱部署一直是一個難以解決的問題,目前的 Java 虛擬機(jī)只能實現(xiàn)方法體的修改熱部署,對于整個類的結(jié)構(gòu)修改,仍然需要重啟虛擬機(jī),對類重新加載才能完成更新操作。下面我=我們就看看對于簡單的類修改的熱部署怎么實現(xiàn)。
2. 原理
深層原理是使用了兩個ClassLoader,一個Classloader加載那些不會改變的類(第三方Jar包),另一個ClassLoader加載會更改的類,稱為restart ClassLoader,這樣在有代碼更改的時候,原來的restart ClassLoader 被丟棄,重新創(chuàng)建一個restart ClassLoader,由于需要加載的類相比較少,所以實現(xiàn)了較快的重啟時間。
3. 方式
springboot有3中熱部署方式:
1.使用springloaded配置pom.xml文件,使用mvn spring-boot:run啟動
2.使用springloaded本地加載啟動,配置jvm參數(shù)
-javaagent:<jar包地址> -noverify
3.使用devtools工具包,操作簡單,但是每次需要重新部署
這里主要講解一下第三種熱部署方式的使用,因為在網(wǎng)上查找資源時,總會發(fā)現(xiàn)很多人就是springloaded和devtools都使用了,其實是多余的操作,而且第三種操作簡單快捷。
4. 開始配置
4.1 在pom.xml中添加依賴
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--devtools熱部署-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
<scope>true</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
</plugins>
</build>
注:
(1) devtools可以實現(xiàn)頁面熱部署(即頁面修改后會立即生效,這個可以直接在application.properties文件中配置spring.thymeleaf.cache=false來實現(xiàn)),
實現(xiàn)類文件熱部署(類文件修改后不會立即生效),實現(xiàn)對屬性文件的熱部署。
即devtools會監(jiān)聽classpath下的文件變動,并且會立即重啟應(yīng)用(發(fā)生在保存時機(jī)),注意:因為其采用的虛擬機(jī)機(jī)制,該項重啟是很快的
(2)配置了true后在修改java文件后也就支持了熱啟動,不過這種方式是屬于項目重啟(速度比較快的項目重啟),會清空session中的值,也就是如果有用戶登陸的話,項目重啟后需要重新登陸。
默認(rèn)情況下,/META-INF/maven,/META-INF/resources,/resources,/static,/templates,/public這些文件夾下的文件修改不會使應(yīng)用重啟,但是會重新加載(devtools內(nèi)嵌了一個LiveReload server,當(dāng)資源發(fā)生改變時,瀏覽器刷新)。
4.2 devtools的配置
在application.yml中配置一下devtools
spring: devtools: restart: enabled: true #設(shè)置開啟熱部署 additional-paths: src/main/java #重啟目錄 exclude: WEB-INF/** freemarker: cache: false #頁面不加載緩存,修改即時生效
4.3 IDEA中配置
當(dāng)我們修改了類文件后,idea不會自動編譯,得修改idea設(shè)置。
(1)File-Settings-Compiler-Build Project automatically
(2)ctrl + shift + alt + / ,選擇Registry,勾上 Compiler autoMake allow when app running


4.4 測試
修改類–>保存:應(yīng)用會重啟
修改配置文件–>保存:應(yīng)用會重啟
修改頁面–>保存:應(yīng)用不會重啟,但會重新加載,頁面會刷新
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot自定義全局異常處理器的問題總結(jié)
Springboot框架提供兩個注解幫助我們十分方便實現(xiàn)全局異常處理器以及自定義異常,處理器會優(yōu)先處理更具體的異常類型,如果沒有找到匹配的處理器,那么它會尋找處理更一般異常類型的處理器,本文介紹SpringBoot自定義全局異常處理器的問題,一起看看吧2024-01-01
Spring Bean創(chuàng)建和循環(huán)依賴
這篇文章主要介紹了Spring Bean創(chuàng)建和循環(huán)依賴,講述了Spring容器中?Bean?的創(chuàng)建過程已經(jīng)主要的方法,另外也著重分析了循環(huán)依賴的問題,需要的小伙伴可以參考一下2022-05-05
Spring中的@PathVariable注解詳細(xì)解析
這篇文章主要介紹了Spring中的@PathVariable注解詳細(xì)解析,@PathVariable 是 Spring 框架中的一個注解,用于將 URL 中的變量綁定到方法的參數(shù)上,它通常用于處理 RESTful 風(fēng)格的請求,從 URL 中提取參數(shù)值,并將其傳遞給方法進(jìn)行處理,需要的朋友可以參考下2024-01-01
SpringCloud Feign轉(zhuǎn)發(fā)請求頭(防止session失效)的解決方案
這篇文章主要介紹了SpringCloud Feign轉(zhuǎn)發(fā)請求頭(防止session失效)的解決方案,本文給大家分享兩種解決方案供大家參考,感興趣的朋友跟隨小編一起看看吧2020-10-10

