本文主要介紹兩種熱部署方式:devtools 與Jrebeljava
spring-boot-devtools 是一個爲開發者服務的一個模塊,其中最重要的功能就是自動應用代碼更改到最新的App上面去。相關Blog: 點擊打開連接 spring
原理是在發現代碼有更改以後,從新啓動應用,可是比速度比手動中止後再啓動還要更快,更快指的不是節省出來的手工操做的時間。編程
其深層原理是使用了兩個ClassLoader,一個Classloader加載那些不會改變的類(第三方Jar包),另外一個ClassLoader加載會更改的類,稱爲 restart ClassLoader,這樣在有代碼更改的時候,原來的restart ClassLoader 被丟棄,從新建立一個restart ClassLoader,因爲須要加載的類相比較少,因此實現了較快的重啓時間(5秒之內)。瀏覽器
那如何使用呢,大概兩個步驟便可:app
第一就是添加相應的依賴:eclipse
<!--devtools能夠實現頁面熱部署(即頁面修改後會當即生效,這個能夠直接在application.properties文件中配置spring.thymeleaf.cache=false來實現), 實現類文件熱部署(類文件修改後不會當即生效),實現對屬性文件的熱部署。 即devtools會監聽classpath下的文件變更,而且會當即重啓應用(發生在保存時機),注意:由於其採用的虛擬機機制,該項重啓是很快的 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> <scope>true</scope> </dependency>
第二加點:僅僅加入devtools在咱們的eclipse中還不起做用,這時候還須要添加的spring-boot-maven-plugin:maven
<build> <finalName>www.fitness.manager.com</finalName> <plugins> <!--用於將應用打成可直接運行的jar(該jar就是用於生產環境中的jar) 值得注意的是,若是沒有引用spring-boot-starter-parent作parent,且採用了上述的第二種方式,這裏也要作出相應的改動 --> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <!--fork: 若是沒有該項配置,devtools不會起做用,即應用不會restart --> <fork>true</fork> </configuration> </plugin> </plugins> </build>
運行App.Java ---- Run Application--- Java Application便可進行測試。ide
測試方法:spring-boot
· 修改類-->保存:應用會重啓工具
· 修改配置文件-->保存:應用會重啓
· 修改頁面-->保存:應用會重啓,頁面會刷新(原理是將spring.thymeleaf.cache設爲false)
不能使用分析:
(a) 對應的spring-boot版本是否正確,我這裏使用的是1.3.3版本;
(b) 是否加入plugin了,以及屬性<fork>true</fork>
(c) 編程工具是否開通自動編譯功能:
Intelj idea 開啓Build project automatically
ctrl + shift + alt + /,選擇Registry,勾上 Compiler autoMake allow when app running
(d) 若是設置SpringApplication.setRegisterShutdownHook(false)
,則自動重啓將不起做用。
補充:默認狀況下,/META-INF/maven,/META-INF/resources,/resources,/static,/templates,/public這些文件夾下的文件修改不會使應用重啓,可是會從新加載(devtools內嵌了一個LiveReload server,當資源發生改變時,瀏覽器刷新)。
· 若是想改變默認的設置,能夠本身設置不重啓的目錄:spring.devtools.restart.exclude=static/**,public/**,這樣的話,就只有這兩個目錄下的文件修改不會致使restart操做了。
· 若是要在保留默認設置的基礎上還要添加其餘的排除目錄:spring.devtools.restart.additional-exclude
· 若是想要使得當非classpath下的文件發生變化時應用得以重啓,使用:spring.devtools.restart.additional-paths,這樣devtools就會將該目錄列入了監聽範圍。
設置 spring.devtools.restart.enabled 屬性爲false,能夠關閉該特性。能夠在application.properties中設置,也能夠經過設置環境變量的方式。
publicstaticvoidmain(String[] args){ System.setProperty("spring.devtools.restart.enabled","false"); SpringApplication.run(MyApp.class, args); }
在intelj IDEA工具中,File->settings->Plugins中搜索Jrebel插件
而後下載插件,下載完成後會在Settings左側菜單欄中出現JRebel。