開始我的SpringBoot學(xué)習(xí)之旅!
全部章節(jié)傳送門:
Spring Boot學(xué)習(xí)筆記(一):Spring Boot 入門基礎(chǔ)
Spring Boot學(xué)習(xí)筆記(二):Spring Boot 運(yùn)行原理
Spring Boot學(xué)習(xí)筆記(三):Spring Boot Web開發(fā)
Spring Boot學(xué)習(xí)筆記(四):Spring Boot 數(shù)據(jù)訪問(wèn)
Spring Boot學(xué)習(xí)筆記(五):Spring Boot 企業(yè)級(jí)開發(fā)
Spring Boot學(xué)習(xí)筆記(六):Spring Boot 應(yīng)用監(jiān)控
SpringBoot概述
SpringBoot是由Pivotal團(tuán)隊(duì)提供的全新框架,其設(shè)計(jì)目的是用來(lái)簡(jiǎn)化新Spring應(yīng)用的初始搭建以及開發(fā)過(guò)程。
SpringBoot使用“習(xí)慣優(yōu)于配置”的理念讓項(xiàng)目快速運(yùn)行起來(lái),使用SpringBoot很容易創(chuàng)建一個(gè)獨(dú)立運(yùn)行(運(yùn)行jar,內(nèi)嵌Servlet容器)、準(zhǔn)生產(chǎn)級(jí)別的基于Spring框架的項(xiàng)目,使用Spring Boot可以不用或者只需要很少的Spring配置。
SpringBoot核心功能
獨(dú)立運(yùn)行的Spring項(xiàng)目
SpringBoot可以以jar包的形式被獨(dú)立運(yùn)行,運(yùn)行一個(gè)SpringBoot項(xiàng)目只需通過(guò)java -jar xx.jar來(lái)運(yùn)行。
內(nèi)嵌Servlet容器
SpringBoot可選擇內(nèi)嵌Tomcat、Jetty或者Undertow,這樣我們無(wú)需以war包形式部署項(xiàng)目。
提供start簡(jiǎn)化Maven配置
Spring提供了一系列的starter pom來(lái)簡(jiǎn)化Maven的依賴加載,例如,當(dāng)你使用了spring-boot-starter-web時(shí),會(huì)自動(dòng)加入依賴包。
自動(dòng)配置Spring
SpringBoot會(huì)根據(jù)在類路徑中的jar包、類,為jar包里的類自動(dòng)配置Bean,這樣會(huì)極大地減少我們要使用的配置。
準(zhǔn)生產(chǎn)的應(yīng)用監(jiān)控
SpringBoot提供基于http、ssh、telnet對(duì)運(yùn)行時(shí)的項(xiàng)目進(jìn)行監(jiān)控。
無(wú)代碼生成和XML配置
SpringBoot不需要任何XML配置即可實(shí)現(xiàn)Spring的所有配置。
SpringBoot優(yōu)點(diǎn)
- 快速構(gòu)建項(xiàng)目;
- 對(duì)主流開發(fā)框架的無(wú)配置集成;
- 項(xiàng)目可以獨(dú)立運(yùn)行,無(wú)需外部依賴Servlet容器;
- 提供運(yùn)行時(shí)的應(yīng)用監(jiān)控;
- 極大地提高了開發(fā)、部署效率;
- 與云計(jì)算的天然集成。
SpringBoot環(huán)境搭建
使用IntelliJ IDEA搭建一個(gè)SpringBoot開發(fā)環(huán)境。
新建Spring Assistant項(xiàng)目,如果沒(méi)有Spring Assistant選項(xiàng),需要先在settings->plugins中安裝Spring Assistant插件。

填寫項(xiàng)目信息。

選擇項(xiàng)目使用技術(shù),本項(xiàng)目使用Web技術(shù)。

創(chuàng)建好項(xiàng)目。可以看到在com.wyk.exercise下自動(dòng)生成了ExcerciseApplication類,該類即為入口類。
修改該類,運(yùn)行程序。
package com.wyk.exercise;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@SpringBootApplication
public class ExerciseApplication {
public static void main(String[] args) {
SpringApplication.run(ExerciseApplication.class, args);
}
@RequestMapping("/")
String index() {
return "Hello Spring Boot";
}
}
打開網(wǎng)頁(yè),查看顯示的結(jié)果。

SpringBoot基本配置
入口類
SpringBoot通常有一個(gè)名為*Application的入口類,里面有一個(gè)main方法。類上面的@SpringBootApplication是SpringBoot的核心注解,它是一個(gè)組合注解,源碼如下:
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = {
@Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
public @interface SpringBootApplication {
....
}
從源碼可知,@SpringBootApplication主要包含@SpringBootConfiguration、@EnableAutoConfiguration、@ComponentScan三個(gè)注解。
- SpringBootConfiguration繼承自@Configuration,二者功能也一致,標(biāo)注當(dāng)前類是配置類,并會(huì)在當(dāng)前類內(nèi)部聲明一個(gè)或多個(gè)@Bean注解標(biāo)記的方法的實(shí)例納入Spring容器中,并且實(shí)例名就是方法名。
- @EnableAutoConfiguration的作用是啟動(dòng)自動(dòng)配置,SpringBoot根據(jù)你添加的jar包來(lái)配置你的項(xiàng)目的默認(rèn)配置。例如添加了spring-boot-starter-web依賴,會(huì)自動(dòng)添加tomcat和SpringMVC的依賴,那么SpringBoot會(huì)對(duì)Tomcat和SpringMVC進(jìn)行自動(dòng)配置。
- @ComponentScan,掃描當(dāng)前包及其子包下被@Component,@Controller,@Service,@Repository注解標(biāo)記的類并納入到spring容器中進(jìn)行管理。是以前的<context:component-scan>
如果要關(guān)閉特定的注解,可以使用@SpringBootApplication注解的exclude參數(shù)。
@SpringBootApplicaiotn(exlude={DataSourceAutoConfiguration.class})
定制Banner
在Spring啟動(dòng)的時(shí)候會(huì)有一個(gè)默認(rèn)啟動(dòng)圖案,此圖案可以進(jìn)行修改。在src/main/resources目錄下新建一個(gè)banner.txt。
通過(guò)http://patorjk.com/software/taag 網(wǎng)站生成字符,將生成的字符復(fù)制到banner.txt中。運(yùn)行程序,發(fā)現(xiàn)果然變成了加入的字符。

如果要關(guān)閉banner,可以把main里的內(nèi)容改為:
public static void main(String[] args) {
//SpringApplication.run(ExerciseApplication.class, args);
SpringApplication app = new SpringApplication(ExerciseApplication.class);
app.setBannerMode(Banner.Mode.OFF);
app.run(args);
}
配置文件
SpringBoot使用一個(gè)全局配置文件application.properties(推薦使用)或者application.yml。放置到src/main/resources目錄或者類路徑的/config下。
例如,將Tomcat的默認(rèn)端口號(hào)8080改為9090,可以在applciaiton.properties中添加:
server.port=9090
starter pom
SpringBoot提供了簡(jiǎn)化企業(yè)級(jí)開發(fā)絕大多數(shù)場(chǎng)景的starter pom,只要使用相關(guān)的starter pom,技術(shù)配置將會(huì)消除。
XML配置
SpringBoot提倡無(wú)XML配置,但實(shí)際中有一些特殊要求必須使用XML,這時(shí)可以通過(guò)Spring提供的@ImportResource來(lái)加載XML配置。
@ImportResource({"classpath:some-context.xml", "classpath:another-context.xml"})
SpringBoot外部配置
SpringBoot允許使用properties文件、yaml文件或者命令行參數(shù)作為外部配置。
命令行參數(shù)配置
可以通過(guò)命令行修改相關(guān)配置。比如:
java -jar xx.jar --server.port=9090
常規(guī)屬性配置
在Spring中,注入properties文件里的值的方法是通過(guò)@PropertySource指明properties文件的位置,然后通過(guò)@Value注入值,在SpringBoot中,我們只需在application.properties定義屬性,直接使用@Value注入即可。
在application.properties增加屬性.
app.author=wanyunkai
app.name=spring boot
修改入口類,引入@Value注解。
package com.wyk.exercise;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.Banner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@SpringBootApplication
public class ExerciseApplication {
@Value("${app.author}")
private String appAuthor;
@Value("${app.name}")
private String appName;
public static void main(String[] args) {
//SpringApplication.run(ExerciseApplication.class, args);
SpringApplication app = new SpringApplication(ExerciseApplication.class);
app.setBannerMode(Banner.Mode.OFF);
app.run(args);
}
@RequestMapping("/")
String index() {
return "App name is: " + appName + " and app author is: " + appAuthor;
}
}
運(yùn)行程序,在瀏覽器查看結(jié)果。

類型安全的配置
上一種方式使用@Value注入在配置較多的時(shí)候會(huì)比較麻煩。SpringBoot還可以通過(guò)@ConfigurationProperties將properties屬性和一個(gè)Bean及其屬性關(guān)聯(lián),從而實(shí)現(xiàn)類型安全的配置。
在application.properties中添加屬性,也可以添加到其他文件中,不過(guò)要指定位置。
app.name=spring boot
app.age=1
創(chuàng)建一個(gè)Bean,通過(guò)@ConfigurationProperties注解來(lái)加載properties文件屬性,通過(guò)prefix屬性指定前綴,通過(guò)locations指定文件位置(本例中不需要)。
package com.wyk.exercise.config;
import org.springframework.stereotype.Component;
import org.springframework.boot.context.properties.ConfigurationProperties;
@Component
@ConfigurationProperties(prefix = "app")
public class AppSettings {
private String name;
private Long age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Long getAge() {
return age;
}
public void setAge(Long age) {
this.age = age;
}
}
修改入口類。
package com.wyk.exercise;
import com.wyk.exercise.config.AppSettings;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.Banner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@SpringBootApplication
public class ExerciseApplication {
@Autowired
private AppSettings appSettings;
public static void main(String[] args) {
//SpringApplication.run(ExerciseApplication.class, args);
SpringApplication app = new SpringApplication(ExerciseApplication.class);
app.setBannerMode(Banner.Mode.OFF);
app.run(args);
}
@RequestMapping("/")
String index() {
return "App name is: " + appSettings.getName() + " and Age is: "
+ appSettings.getAge();
}
}
SpringBoot日志配置
SpringBoot支持多種日志框架,默認(rèn)情況下,SpringBoot使用Logback作為日志框架。
配置日志文件:
logging.file=D:/mylog/log.log
配置日志級(jí)別,格式為logging.level.包名=級(jí)別:
loggging.level.org.springframework.web=DEBUG
SpringBoot Profie配置
Profile是Spring用來(lái)針對(duì)不同環(huán)境對(duì)不同的配置提供支持,全局Profile配置使用application-{profile}.properties(如applicaiton-prod.properties)。通過(guò)在applicaiton.properties中設(shè)置spring.profiles.active=prod來(lái)指定活動(dòng)的Profile。