这可能是分布式开发的前奏,什么是分布式开发,一般在学校里面写的springboot项目,只有application.properties或者是application.yml文件中的一个配置信息,例如:
application.yml文件中:
#server
server:
port: 8080
servlet:
context-path: /
tomcat:
threads:
max: 1000
#spring
spring:
datasource:
url: jdbc:mysql:///jtsys?serverTimezone=GMT
username: root
password: root
thymeleaf:
prefix: classpath:/templates/pages/
suffix: .html
#mybatis
mybatis:
configuration:
default-statement-timeout: 30
map-underscore-to-camel-case: true
mapper-locations:
- classpath:/mapper/*.xml
#LOG
logging:
level:
com.cy: DEBUG
这种一般是单体开发(一个服务器)
而分布式开发,是多个服务器在同一个项目中去使用,可能是一个子系统一个专门使用的服务器。
01.所以,首先去了解相关的注解。
@value,这个注解的功能是 在项目启动的时候,会自动的去获取yml中的配置信息,并且动态的实现数据的获取和封装。
新编辑一个项目的yml文件:
#server端口号
server:
port: 8090
servlet:
context-path: /
animal:
name: 老虎
age: 20
再写一个controller类文件:
@RestController
public class AnimalController {
@Value("${animal.name}")
private String name;
@Value("${animal.age}")
private int age;
@RequestMapping("/getAnimal")
public String getAnimal() {
return name+":"+age;
}
}
@Value(“${animal.name}”)其中,animal是yml文件的一级标题,而name是隶属于animal的二级标题,使用这些后,@value会自动的从yml获取相关数据,并且赋值给修饰的类的属性。
02@ConfigurationProperties注解批量为属性赋值
第一步:先要注入依赖:
<!--添加属性注入依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
第二步:编辑AnimalController
注意:使用批量赋值操作时,需要使用@ConfigurationProperties注解.并且需要指定数据的前缀类型.同
时必须添加属性的set/get方法,如果指定了前缀,并且如果属性名称相同,则可以利用set方法位属性赋值
@RestController
@ConfigurationProperties(prefix = "animal")
public class AnimalController {
//如果指定了前缀,并且如果属性名称相同,则可以利用set方法位属性赋值
private String name;
private int age;
@RequestMapping("/getAnimal")
public String getAnimal() {
return name+":"+age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
03.当有多个properties文件时候,@value需要如何去赋值?
编辑一个controller类personcontroller:
@RestController
@PropertySource("classpath:/properties/person.properties")
public class PersonController {
@Value("${person.id}")
private int id;
@Value("${person.name}")
private String name;
@RequestMapping("/getPerson")
public String getMsg() {
return id+":"+name;
}
}
@PropertySource(“classpath:/properties/person.properties”)用来准确的获取properties文件的位置,否则@value注解就会去yml文件中去寻找,因为项目一启动就会自动加载这个文件。