Spring Cloud Config(1)快速应用
配置中心管理,本文旨在快速搭建一个Spring Cloud Config的应用demo;将在后续文章更深入的分析。
本文所用的基本版本
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<java.version>15</java.version>
<spring-cloud.version>2020.0.1</spring-cloud.version>
</properties>
1、静态配置文件
client-dev.yml文件放置本地目录,或者远程仓库中;
#后面client读取到就会以这个端口号启动
server:
port: 8081
nickName: new world
2、config服务器
2.1、依赖包
pom.xml
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
2.2、配置文件
properites.yml
存放在本地的情况:
server:
port: 8080 #端口号
#读取本地
spring:
application:
name: config-server #服务名
profiles:
active: native
cloud:
config:
server:
native:
searchLocations: D:/../Cloud/config/config #前面创建的配置文件的目录
如果是放在远程仓库的情况:
server:
port: 8080 #端口号
spring:
application:
name: config-server
cloud:
config:
server:
git:
uri: https://github.com/../configcenter # git仓库的地址
search-paths: springcloud-config # git仓库地址下的相对地址,可以配置多个,用逗号分割。
username: #Git仓库用户名
password: #Git仓库密码
2.3、应用入口
@SpringBootApplication
@EnableConfigServer //声明为配置文件服务器 为client提供配置读取服务
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class, args);
}
}
3、客户端
3.1、依赖包
pom.xml
<!--
为调试应用controller准备
-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--从2.4.0版本后bootstrap被分离为单独一个服务应用
如果需要从bootstrap.yml或bootstrap.properties启动则需要引入此依赖
-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
3.2、配置文件
properties.yml
#端口号从配置文件服务器中获取
spring:
application:
name: config-client
cloud:
config:
uri: http://localhost:8080
name: client #对应仓库的配置文件格式:{name}-{profile}.yml/properties
profile: dev
label: master
profiles:
active: dev
# springboot 1.5.X 以上默认开通了安全认证,所以需要添加这个配置
management:
security:
enabled: false
3.3、测试
HelloController .java
@RestController
public class HelloController {
//可以debug查看所有的环境配置信息
@Autowired
private Environment env;
//如果能正常说明已经获取了服务器的配置
@Value("${nickName}")
private String nickName;
@RequestMapping("/hello")
public String hello(){
return "Hello "+nickName;
}
}
启动服务以及客户端,访问客户端的测试地址,可以读取到服务器提供的配置。