Spring Boot (2)devtools熱部署與Jrebel熱部署

本文主要介紹兩種熱部署方式:devtools 與Jrebeljava

devtools

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);
}

Jrebel

在intelj IDEA工具中,File->settings->Plugins中搜索Jrebel插件

而後下載插件,下載完成後會在Settings左側菜單欄中出現JRebel。

相關文章
相關標籤/搜索