一。 开发工具
springboot包含了一些开发工具集 只需要引用 spring-boot-devtools 依赖 开发工具在开发阶段默认开启 在被打包的程序 比如jar包 通过 java -jar运行
自动禁用 开发工具集
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
在spring.properties添加启动配置 (添加了maven依赖 该参数默认为true 如果想禁用 改成false)
spring.devtools.restart.enabled=true
springboot可以定制哪些资源会自动重启 哪些资源不会自动重启 (静态资源如图片等)
spring-boot-devtools-1.5.7.RELEASE.jar下DevToolsSettings中定义了开发工具的逻辑
public static final String SETTINGS_RESOURCE_LOCATION = "META-INF/spring-devtools.properties";
具体参考https://docs.spring.io/spring-boot/docs/1.5.7.RELEASE/reference/htmlsingle/#using-boot-devtools
二。 自定义Banner
springboot默认启动时 输出的图标就是banner 比如
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.5.7.RELEASE)
spring提供了自定义banner的方式在 src/main/resources添加文件banner.txt 添加特殊的自定义符号 在该txt中可以使用资源文件的一些特殊信息
参考(https://docs.spring.io/spring-boot/docs/1.5.7.RELEASE/reference/htmlsingle/#boot-features-banner)
比如我的banner.txt为
╭⌒╮¤ ` ${application.version}
╭╭ ⌒╮ ●╭○╮ ${spring-boot.version}
╰ ----╯/█∨█\
~~~~~~~~~~∏~~∏~~~~~~~~~~~
运行后显示的效果为
17:08:42.628 [main] DEBUG org.springframework.boot.devtools.settings.DevToolsSettings - Included patterns for restart : []
17:08:42.644 [main] DEBUG org.springframework.boot.devtools.settings.DevToolsSettings - Excluded patterns for restart : [/.*.txt, /spring-boot-starter/target/classes/, /spring-boot-autoconfigure/target/classes/, /spring-boot-starter-[\w-]+/, /spring-boot/target/classes/, /spring-boot-actuator/target/classes/, /spring-boot-devtools/target/classes/]
17:08:42.644 [main] DEBUG org.springframework.boot.devtools.restart.ChangeableUrls - Matching URLs for reloading : [file:/C:/Users/jiaozi/Documents/workspace-sts-3.9.0.RELEASE/sb/target/classes/, file:/C:/Users/jiaozi/Documents/workspace-sts-3.9.0.RELEASE/sbbean/target/classes/]
╭⌒╮¤ ` 1290
╭╭ ⌒╮ ●╭○╮ 1.5.7.RELEASE
╰ ----╯/█∨█\
~~~~~~~~~~∏~~∏~~~~~~~~~~~
三。随机值
springboot可以在properties文件中使用表达式产生一些随机值 比如
my.secret=${random.value}
my.number=${random.int}
my.bignumber=${random.long}
my.uuid=${random.uuid}
my.number.less.than.ten=${random.int(10)}
my.number.in.range=${random.int[1024,65536]}
具体参考https://docs.spring.io/spring-boot/docs/1.5.7.RELEASE/reference/htmlsingle/#boot-features-external-config-random-values
四。 Profiles
springboot允许使用 profile来定义不同环境下的不同配置 比如在开发环境下 使用mysql 正式环境下用oracle 如果直接修改配置 非常麻烦
可以在程序中预设好mysql和oracle的环境 通过不同的标志来标志 当启动程序 传入哪个标识就加载哪个配置 这就是profiles
以下举例 假设有个接口是Db 有两个实现类 Mysql和Oracle 分别给添加两个配置类 定义不同的profile
添加接口和实现类
package cn.et.profile;
/**
* 定义接口
* @author jiaozi
*
*/
public interface Db {
String getName();
}
/**
* 定义mysql实现类
* @author jiaozi
*
*/
class Mysql implements Db{
@Override
public String getName() {
return "mysql";
}
}
/**
* 定义oracle实现类
* @author jiaozi
*
*/
class Oracle implements Db{
@Override
public String getName() {
return "oracle";
}
}
分别定义两个profile分别是开发环境(实例化mysql的bean)和生产环境(实例化oracle的bean)
开发环境profile定义
package cn.et.profile;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
@Profile(value="dev")
@Configuration
public class DataSourceBeanDev {
@Bean
public Db testBean() {
return new Mysql();
}
}
生产环境profile定义
package cn.et.profile;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
@Profile(value="product")
@Configuration
public class DataSourceBeanProduct {
@Bean
public Db testBean() {
return new Oracle();
}
}
添加一个控制层的rest类
package cn.et.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import cn.et.profile.Db;
@RestController
public class TestController {
@Autowired
private Db db;
@GetMapping("/q")
public String query() {
return db.toString()+"=="+db.getClass().getTypeName();
}
}
添加main方法
package cn.et;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.PropertySource;
@SpringBootApplication
public class SbApplication {
public static void main(String[] args) {
SpringApplication sa=new SpringApplication();
sa.run(SbApplication.class, args);
}
}
application.properties 添加当前启动激活的profile
spring.profiles.active=product
启动后访问 http://localhost:8080/q 页面输出的是Oracle的实例
修改spring.profiles.active=dev 页面输出的Mysql的实例
打包的程序 可以通过 java -jar a.jar --spring.profiles.active=product 来传递参数覆盖spring.properties参数
springboot还可以添加一些额外的启动profile
spring.profiles: dev #激动dev
spring.profiles.include:#同时激活以下所有
- devredis
- devdb
- devmongodb
springboot yaml中可以将yaml中分成多个快 每个快指定 一个profile 参考springboot的 24.4 Profile-specific properties章节以及24.6.3 Multi-profile YAML documents
比如
server:
address: 192.168.1.100
---
spring:
profiles: development
server:
address: 127.0.0.1
---
spring:
profiles: production
server:
address: 192.168.1.120
如果active的profile是development server的ip地址就是 127.0.0.1 如果是 production ip就是192.168.1.20 如果都没有指定就是192.168.1.100
五。 日志配置
springboot默认使用common-logging进行日志记录 日志分为以下几个级别
FATAL 错误可能导致程序崩溃
ERROR 一般为异常 程序继续运行
WARN 警告信息 非错误
INFO 程序正常运行记录信息
DEBUG 调试信息
TRACE 跟踪信息 级别最低
一般设置为 某个级别 大于该级别之上所有级别日志都输出 级别从低到高依次为:
FATAL-DEBUG-INFO-WARN-ERROR -FATAL
springboot默认的级别是INFO
通过在spring.properties中 设置debug=true设置级别为debug trace=true设置级别为trace
其他的级别通过以下配置设置
logging.level.root=ERROR
可以将日志定位输出到文件 (以下两个配置只能一个生效 都配置了 file生效)
logging.path=d:/logs #在该目录下生成 spring.log日志文件
logging.file=my.log #当前项目下 生成该文件
其他的日志配置参考
https://docs.spring.io/spring-boot/docs/1.5.7.RELEASE/reference/htmlsingle/#boot-features-logging