Spring Boot使用了一个全局的配置文件application.properties,放在src/main/resources目录下或者类路径的/config下。Sping Boot的全局配置文件的做用是对一些默认配置的配置值进行修改。接下来,让咱们一块儿来解开配置文件的面纱。java
注:若是你工程没有这个application.properties,那就在src/main/java/resources目录下新建一个。web
application.properties提供自定义属性的支持,这样咱们就能够把一些常量配置在这里:spring
com.qiuqiu.name="球球" com.qiuqiu.want="祝你们鸡年大吉!"
而后直接在要使用的地方经过注解@Value(value=”${XXX}”)就能够绑定到你想要的属性上面数据库
@RestController public class UserController { @Value("${com.qiuqiu.name}") private String name; @Value("${com.qiuqiu.want}") private String want; @RequestMapping("/hello") public String hello(){ return name+","+want; } }
属性不少时,一个个绑定到属性字段上太麻烦,官方提倡绑定一个对象的bean,这里咱们建一个ConfigBean.java类,顶部须要使用注解@ConfigurationProperties(prefix = “XXX”)来指明使用哪一个 tomcat
@ConfigurationProperties(prefix = "com.qiuqiu") public class ConfigBean { private String name; private String want; // 省略getter和setter }
Spring Boot 会自动转换类型,当使用List
的时候须要注意在配置中对List
进行初始化!Spring Boot 还支持嵌套属性注入。app
name=Isea533 servers[0]=dev.bar.com servers[1]=foo.bar.com jdbc.username=root jdbc.password=root
@ConfigurationProperties public class Config { private String name; private List<String> servers = new ArrayList<String>(); private Jdbc jdbc; // 省略getter和setter class Jdbc { private String username; private String password; // 省略getter和setter } }
另一种使用配置文件属性的方式,在@Bean方法上使用@ConfigurationPropertiesless
@ConfigurationProperties(prefix = "com.qiuqiu") @Bean public ConfigBean configBean() { ... }
例如:dom
app.name=MyApp app.description=${app.name} is a Spring Boot application
能够在配置文件中引用前面配置过的属性(优先级前面配置过的这里都能用)。经过如${app.name:默认名称}方法还能够设置默认值,当找不到引用的属性时,会使用默认的属性。因为${}方式会被Maven处理。若是你pom继承的spring-boot-starter-parent,Spring Boot 已经将maven-resources-plugins默认的${}方式改成了@ @方式,例如@name@。若是你是引入的Spring Boot,你能够修改使用其余的分隔符。 maven
经过属性占位符还能缩短命令参数ide
例如修改web默认端口须要使用--server.port=9090方式,若是在配置中写上:
server.port=${port:8080}
那么就可使用更短的--port=9090,当不提供该参数的时候使用默认值8080。
有时咱们不但愿把全部配置都放在application.properties里面,这时候咱们能够另外定义一个,这里咱们定义一个名为test.properties配置文件,路径跟也放在src/main/resources下面。
com.md.name="球球" com.md.want="祝你们鸡年大吉"
@Configuration @ConfigurationProperties(prefix = "com.md") @PropertySource("classpath:test.properties") public class ConfigTestBean { private String name; private String want; // 省略getter和setter }
注:若是你使用的是1.5之前的版本,那么能够经过locations指定properties文件的位置,这样:
@ConfigurationProperties(prefix = "config2",locations="classpath:test.properties")
可是1.5版本以后就没有这个属性,须要添加@Configuration和@PropertySource(“classpath:test.properties”)后才能够读取。
配置文件中${random.*} 能够用来生成各类不一样类型的随机值,从而简化了代码生成的麻烦,例如 生成 int 值、long 值或者 string 字符串。
qiuqiu.secret=${random.value} qiuqiu.number=${random.int} qiuqiu.bignumber=${random.long} qiuqiu.uuid=${random.uuid} qiuqiu.number.less.than.ten=${random.int(10)} qiuqiu.number.in.range=${random.int[1024,65536]}
Spring Boot是基于jar包运行的,打成jar包的程序能够直接经过下面命令运行:
java -jar xx.jar
能够如下命令修改tomcat端口号:
java -jar xx.jar --server.port=9090
能够看出,命令行中连续的两个减号--
就是对application.properties
中的属性值进行赋值的标识。
因此java -jar xx.jar --server.port=9090
等价于在application.properties
中添加属性server.port=9090
。
若是你怕命令行有风险,可使用SpringApplication.setAddCommandLineProperties(false)禁用它。
实际上,Spring Boot应用程序有多种设置途径,Spring Boot能从多重属性源得到属性,包括以下几种:
~/.spring-boot-devtools.properties
)。SPRING_APPLICATION_JSON
中的属性(环境变量或系统属性中的内联JSON嵌入)。ServletConfig
初始化参数。ServletContext
初始化参数。SpringApplication.setDefaultProperties
指定).这里列表按组优先级排序,也就是说,任何在高优先级属性源里设置的属性都会覆盖低优先级的相同属性,例如咱们上面提到的命令行属性就覆盖了application.properties的属性。
application.properties和application.yml文件能够放在如下四个位置:
一样,这个列表按照优先级排序,也就是说,src/main/resources/config下application.properties覆盖src/main/resources下application.properties中相同的属性,如图:
此外,若是你在相同优先级位置同时有application.properties和application.yml,那么application.properties里的属性里面的属性就会覆盖application.yml。
当应用程序须要部署到不一样运行环境时,一些配置细节一般会有所不一样,最简单的好比日志,生产日志会将日志级别设置为WARN或更高级别,并将日志写入日志文件,而开发的时候须要日志级别为DEBUG,日志输出到控制台便可。
若是按照之前的作法,就是每次发布的时候替换掉配置文件,这样太麻烦了,Spring Boot的Profile就给咱们提供了解决方案,命令带上参数就搞定。
在Spring Boot中多环境配置文件名须要知足application-{profile}.properties
的格式,其中{profile}
对应你的环境标识,好比:
想要使用对应的环境,只须要在application.properties中使用spring.profiles.active属性来设置,值对应上面提到的{profile},这里就是指dev、prod这2个。
固然你也能够用命令行启动的时候带上参数:
java -jar xxx.jar --spring.profiles.active=dev
除了能够用profile的配置文件来分区配置咱们的环境变量,在代码里,咱们还能够直接用@Profile注解来进行配置,例如数据库配置,这里咱们先定义一个接口 :
public interface DBConnector { public void configure(); }
定义俩个实现类来实现它:
/** * 测试数据库 */ @Component @Profile("testdb") public class TestDBConnector implements DBConnector { @Override public void configure() { System.out.println("testdb"); } } /** * 生产数据库 */ @Component @Profile("devdb") public class DevDBConnector implements DBConnector { @Override public void configure() { System.out.println("devdb"); } }
经过在配置文件激活具体使用哪一个实现类
spring.profiles.active=testdb
而后就能够以下方使用:
@RestController @RequestMapping("/task") public class TaskController { @Autowired DBConnector connector ; @RequestMapping(value = "/hello") public String helloTask(){ connector.configure(); //最终打印testdb return "hello task !! myage is " + myage; } }
除了spring.profiles.active来激活一个或者多个profile以外,还能够用spring.profiles.include来叠加profile。
spring.profiles.active=testdb spring.profiles.include=proddb,prodmq
import org.springframework.boot.bind.RelaxedPropertyResolver; import org.springframework.context.EnvironmentAware; import org.springframework.context.annotation.Configuration; import org.springframework.core.env.Environment; @Configuration public class MyEnvironmentAware implements EnvironmentAware { /** * 注意重写的方法 setEnvironment是在系统启动的时候被执行。 */ @Override public void setEnvironment(Environment environment) { // 经过 environment 获取到系统属性. System.out.println(environment.getProperty("JAVA_HOME")); // 经过 environment 一样能获取到application.properties配置的属性. System.out.println(environment.getProperty("spring.datasource.url")); // 获取到前缀是"spring.datasource." 的属性列表值. RelaxedPropertyResolver relaxedPropertyResolver = new RelaxedPropertyResolver(environment, "spring.datasource."); System.out.println("spring.datasource.url=" + relaxedPropertyResolver.getProperty("url")); System.out.println("spring.datasource.driverClassName=" + relaxedPropertyResolver.getProperty("driverClassName")); } }
import org.springframework.beans.BeansException; import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; import org.springframework.core.env.Environment; import org.springframework.stereotype.Component; import org.springframework.util.StringUtils; @Component public class SpringCtxHolder implements ApplicationContextAware { private static ApplicationContext applicationContext; private static Environment env; public static ApplicationContext getApplicationContext() { return applicationContext; } @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { SpringCtxHolder.applicationContext = applicationContext; env = applicationContext.getEnvironment(); } public static Environment getEnv() { return env; } public static void setEnv(Environment env) { SpringCtxHolder.env = env; } public static String getProperty(String key) { if (StringUtils.isEmpty(key)) { return ""; } return env.getProperty(key); } }
SpringCtxHolder.getProperty("spring.datasource.url");