您的位置:首页 > 编程语言 > Java开发

Spring Boot 支持多种外部配置方式

2017-11-06 11:58 375 查看
这些方式优先级如下:
命令行参数
来自
java:comp/env
的JNDI属性
Java系统属性(
System.getProperties()

操作系统环境变量
RandomValuePropertySource
配置的
random.*
属性值
jar
包外部的
application-{profile}.properties
application.yml
(带
spring.profile
)配置文件
jar
包内部的
application-{profile}.properties
application.yml
(带
spring.profile
)配置文件
jar
包外部的
application.properties
application.yml
(不带
spring.profile
)配置文件
jar
包内部的
application.properties
application.yml
(不带
spring.profile
)配置文件
@Configuration
注解类上的
@PropertySource

通过
SpringApplication.setDefaultProperties
指定的默认属性


命令行参数

通过
java -jar app.jar --name="Spring" --server.port=9090
方式来传递参数。

参数用
--xxx=xxx
的形式传递。

可以使用的参数可以是我们自己定义的,也可以是Spring Boot中默认的参数。

很多人可能会关心如web端口如何配置这样的问题,这些都是Spring Boot中提供的参数,部分可用参数如下:
# LOGGING
logging.path=/var/logs
logging.file=myapp.log
logging.config= # location of config file (default classpath:logback.xml for logback)
logging.level.*= # levels for loggers, e.g. "logging.level.org.springframework=DEBUG" (TRACE, DEBUG, INFO, WARN, ERROR, FATAL, OFF)

# EMBEDDED SERVER CONFIGURATION (ServerProperties)
server.port=8080
server.address= # bind to a specific NIC
server.session-timeout= # session timeout in seconds
server.context-parameters.*= # Servlet context init parameters, e.g. server.context-parameters.a=alpha
server.context-path= # the context path, defaults to '/'
server.servlet-path= # the servlet path, defaults to '/'
1
2
3
4
5
6
7
8
9
10
11
12
13

更多常见的应用属性请浏览这里

注意:命令行参数在
app.jar
的后面!

可以通过
SpringApplication.setAddCommandLineProperties(false)
禁用命令行配置。


Java系统属性

注意Java系统属性位置
java -Dname="isea533" -jar app.jar
,可以配置的属性都是一样的,优先级不同。

例如
java -Dname="isea533" -jar app.jar --name="Spring!"
name
值为
Spring!


操作系统环境变量

配置过JAVA_HOME的应该都了解这一个。

这里需要注意的地方,有些OS可以不支持使用
.
这种名字,如
server.port
,这种情况可以使用
SERVER_PORT
来配置。

具体名字如何匹配,看本文后面。


RandomValuePropertySource

系统中用到随机数的地方,例如:
my.secret=${random.value}
my.number=${random.int}
my.bignumber=${random.long}
my.number.less.than.ten=${random.int(10)}
my.number.in.range=${random.int[1024,65536]}
1
2
3
4
5

random.int*
支持
value
参数和
,max
参数,当提供
max
参数的时候,
value
就是最小值。


应用配置文件(.properties或.yml)

在配置文件中直接写:
name=Isea533
server.port=8080
1
2

.yml
格式的配置文件如:
name: Isea533
server:
port: 8080
1
2
3

当有前缀的情况下,使用
.yml
格式的配置文件更简单。关于
.yml
配置文件用法请看这里

注意:使用
.yml
时,属性名的值和冒号中间必须有空格,如
name:
Isea533
正确,
name:Isea533
就是错的。


属性配置文件的位置

spring会从classpath下的
/config
目录或者classpath的根目录查找
application.properties
application.yml


/config
优先于
classpath根目录


@PropertySource

这个注解可以指定具体的属性配置文件,优先级比较低。


SpringApplication.setDefaultProperties

例如:
SpringApplication application = new SpringApplication(Application.class);
Map<String, Object> defaultMap = new HashMap<String, Object>();
defaultMap.put("name", "Isea-Blog");
//还可以是Properties对象
application.setDefaultProperties(defaultMap);
application.run(args);
1
2
3
4
5
6


应用(使用)属性


@Value(“${xxx}”)

这种方式是最简单的,通过
@Value
注解可以将属性值注入进来。


@ConfigurationProperties

Spring Boot 可以方便的将属性注入到一个配置对象中。例如:
my.name=Isea533
my.port=8080
my.servers[0]=dev.bar.com
my.servers[1]=foo.bar.com
1
2
3
4

对应对象:
@ConfigurationProperties(prefix="my")
public class Config {
private String name;
private Integer port;
private List<String> servers = new ArrayList<String>();

public String geName(){
return this.name;
}

public Integer gePort(){
return this.port;
}
public List<String> getServers() {
return this.servers;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

Spring Boot 会自动将
prefix="my"
前缀为
my
的属性注入进来。

Spring Boot 会自动转换类型,当使用
List
的时候需要注意在配置中对
List
进行初始化!

Spring Boot 还支持嵌套属性注入,例如:
name=isea533
jdbc.username=root
jdbc.password=root
...
1
2
3
4

对应的配置类:
@ConfigurationProperties
public class Config {
private String name;
private Jdbc jdbc;
class Jdbc {
private String username;
private String password;
//getter...
}

public Integer gePort(){
return this.port;
}
public Jdbc getJdbc() {
return this.jdbc;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

jdbc
开头的属性都会注入到
Jdbc
对象中。


在@Bean方法上使用@ConfigurationProperties

例如:
@ConfigurationProperties(prefix = "foo")
@Bean
public FooComponent fooComponent() {
...
}
1
2
3
4
5

Spring Boot 会将
foo
开头的属性按照名字匹配注入到
FooComponent
对象中。


属性占位符

例如:
app.name=MyApp
app.description=${app.name} is a Spring Boot application
1
2

可以在配置文件中引用前面配置过的属性(优先级前面配置过的这里都能用)。

通过如
${app.name:默认名称}
方法还可以设置默认值,当找不到引用的属性时,会使用默认的属性。

由于
${}
方式会被Maven处理。如果你pom继承的
spring-boot-starter-parent
,Spring
Boot 已经将
maven-resources-plugins
默认的
${}
方式改为了
@
@
方式,例如
@name@


如果你是引入的Spring Boot,你可以修改使用其他的分隔符


通过属性占位符还能缩短命令参数

例如修改web默认端口需要使用
--server.port=9090
方式,如果在配置中写上:
server.port=${port:8080}
1

那么就可以使用更短的
--port=9090
,当不提供该参数的时候使用默认值
8080


属性名匹配规则

例如有如下配置对象:
@Component
@ConfigurationProperties(prefix="person")
public class ConnectionSettings {

private String firstName;

}
1
2
3
4
5
6
7

firstName
可以使用的属性名如下:
person.firstName
,标准的驼峰式命名
person.first-name
,虚线(
-
)分割方式,推荐在
.properties
.yml
配置文件中使用
PERSON_FIRST_NAME
,大写下划线形式,建议在系统环境变量中使用


属性验证

可以使用
JSR-303
注解进行验证,例如:
@Component
@ConfigurationProperties(prefix="connection")
public class ConnectionSettings {

@NotNull
private InetAddress remoteAddress;

// ... getters and setters

}
1
2
3
4
5
6
7
8
9
10


最后

以上是Spring Boot 属性配置和使用的内容,有些不全面的地方或者读者有更多疑问,可以查看Spring
Boot完整文档 或 Externalized
Configuration。
转自:http://blog.csdn.net/isea533/article/details/50281151
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐