您好,登錄后才能下訂單哦!
技術(shù)介紹
devtools:是boot的一個(gè)熱部署工具,當(dāng)我們修改了classpath下的文件(包括類文件、屬性文件、頁面等)時(shí),會重新啟動應(yīng)用(由于其采用的雙類加載器機(jī)制,這個(gè)啟動會非???,如果發(fā)現(xiàn)這個(gè)啟動比較慢,可以選擇使用jrebel)
雙類加載器機(jī)制:boot使用了兩個(gè)類加載器來實(shí)現(xiàn)重啟(restart)機(jī)制:base類加載器(簡稱bc)+restart類加載器(簡稱rc)。
bc:用于加載不會改變的jar(eg.第三方依賴的jar)
rc:用于加載我們正在開發(fā)的jar(eg.整個(gè)項(xiàng)目里我們自己編寫的類)。當(dāng)應(yīng)用重啟后,原先的rc被丟掉、重新new一個(gè)rc來加載這些修改過的東西,而bc卻不需要動一下。這就是devtools重啟速度快的原因。
thymeleaf:boot推薦的模板引擎,這里做簡要的介紹,用來介紹devtools對頁面的熱部署。
項(xiàng)目結(jié)構(gòu):
1、pom.xml
<!-- thymeleaf --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <!-- devtools可以實(shí)現(xiàn)頁面熱部署(即頁面修改后會立即生效,這個(gè)可以直接在application.properties文件中配置spring.thymeleaf.cache=false來實(shí)現(xiàn)), 實(shí)現(xiàn)類文件熱部署(類文件修改后不會立即生效),實(shí)現(xiàn)對屬性文件的熱部署。 即devtools會監(jiān)聽classpath下的文件變動,并且會立即重啟應(yīng)用(發(fā)生在保存時(shí)機(jī)),注意:因?yàn)槠洳捎玫奶摂M機(jī)機(jī)制,該項(xiàng)重啟是很快的 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional><!-- optional=true,依賴不會傳遞,該項(xiàng)目依賴devtools;之后依賴myboot項(xiàng)目的項(xiàng)目如果想要使用devtools,需要重新引入 --> </dependency>
說明:如果僅僅使用thymeleaf,只需要引入thymeleaf;如果需要使用devtools,只需要引入devtools。
注意:
maven中的optional=true表示依賴不會傳遞。即此處引用的devtools不會傳遞到依賴myboot項(xiàng)目的項(xiàng)目中。
僅僅加入devtools在我們的eclipse中還不起作用,這時(shí)候還需要對之前添加的spring-boot-maven-plugin做一些修改,如下:
<!-- 用于將應(yīng)用打成可直接運(yùn)行的jar(該jar就是用于生產(chǎn)環(huán)境中的jar) 值得注意的是,如果沒有引用spring-boot-starter-parent做parent, 且采用了上述的第二種方式,這里也要做出相應(yīng)的改動 --> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <fork>true</fork><!-- 如果沒有該項(xiàng)配置,肯呢個(gè)devtools不會起作用,即應(yīng)用不會restart --> </configuration> </plugin>
即添加了fork:true
2、ThymeleafController
package com.xxx.firstboot.web; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @Api("測試Thymeleaf和devtools") @Controller @RequestMapping("/thymeleaf") public class ThymeleafController { @ApiOperation("第一個(gè)thymeleaf程序") @RequestMapping(value = "/greeting", method = RequestMethod.GET) public String greeting(@RequestParam(name = "name", required = false, defaultValue = "world") String name, Model model) { model.addAttribute("xname", name); return "greet"; } }
說明:Model可以作為一個(gè)入?yún)?,在代碼中,將屬性以"key-value"的形式存入model,最后直接返回字符串即可。
3、greet.html
<!DOCTYPE HTML> <html xmlns:th="http://www.thymeleaf.org"> <head> <title>第一個(gè)thymeleaf程序</title> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> </head> <body> <p th:text="'Hello, ' + ${xname} + '!'" /> <div>1234567890!!!xx</div> </body> </html>
注意:
src/main/resources/templates:頁面存放目錄
src/main/resources/static:方式靜態(tài)文件(css、js等)
以上的目錄與ssm中開發(fā)的不一樣,ssm中會放在src/main/webapp下
測試:
修改類-->保存:應(yīng)用會重啟
修改配置文件-->保存:應(yīng)用會重啟
修改頁面-->保存:應(yīng)用不會重啟,但會重新加載,頁面會刷新(原理是將spring.thymeleaf.cache設(shè)為false)
補(bǔ)充:
默認(rèn)情況下,/META-INF/maven,/META-INF/resources,/resources,/static,/templates,/public這些文件夾下的文件修改不會使應(yīng)用重啟,但是會重新加載(devtools內(nèi)嵌了一個(gè)LiveReload server,當(dāng)資源發(fā)生改變時(shí),瀏覽器刷新)。
如果想改變默認(rèn)的設(shè)置,可以自己設(shè)置不重啟的目錄:spring.devtools.restart.exclude=static/**,public/**,這樣的話,就只有這兩個(gè)目錄下的文件修改不會導(dǎo)致restart操作了。
如果要在保留默認(rèn)設(shè)置的基礎(chǔ)上還要添加其他的排除目錄:spring.devtools.restart.additional-exclude
如果想要使得當(dāng)非classpath下的文件發(fā)生變化時(shí)應(yīng)用得以重啟,使用:spring.devtools.restart.additional-paths,這樣devtools就會將該目錄列入了監(jiān)聽范圍。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。