已停止更新,源码及文档请进入https://github.com/huaPeiLiang/spring-cloud-start
1、新建一个Eureka客户端,pom文件添加config依赖。
代码可以参考spring-cloud-start开源项目的config模块。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
<version>2.1.0.M3</version>
</dependency>
2、主启动类上加入@EnableConfigServer注解。
3、配置文件中除了需要向Eureka注册中心注册自己外,还需要指定配置文件存放的地方和路径。(注意:EnvironmentRepository的默认实现使用Git后端,除此之外还支持Vault端及文件系统端)。
spring.profiles.active=native native表示配置文件存放在本地
spring.cloud.config.server.native.search-locations=classpath:/config 指定配置文件存放的路径
4、因为我这里存储配置文件是在本项目的resources/config目录下,所以需要创建文件夹并新建配置文件。命名需要参考以下三个变量:
- {application}映射到客户端的“spring.application.name”;
- {profile}映射到客户端上的“spring.profiles.active”(逗号分隔列表);
- {label}这是一个服务器端功能,标记“版本”的一组配置文件。
5、以上config服务端配置完成。下面需要改造config客户端,使其能够访问并读取config服务端的配置。以hive项目为例,在pom中添加config依赖,(注意:这里添加的依赖和config服务端添加的有所不同)。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
<version>2.1.4.RELEASE</version>
</dependency>
6、在hive项目的resources目录下添加bootstarp配置文件。
EUREKA_SERVER=http://localhost:9991/eureka/
eureka.client.serviceUrl.defaultZone=${EUREKA_SERVER}
spring.cloud.config.discovery.enabled=true
spring.cloud.config.discovery.serviceId=CONFIG-SERVER 需要请求的config-server服务名称
# /{label}/{application}-{profile}.properties
spring.cloud.config.name=common
# 对应的是配置文件规则中的{profile}部分,可以是多个,用逗号隔开。
CONFIG_PROFILE=dev
spring.cloud.config.profile=${CONFIG_PROFILE}
这里也有多种配置方式,还可以通过写死config服务端的地址来读取配置,个人不推荐这种做法。配置完成后先启动config服务端(config),再启动config的客户端(hive)就可以成功从配置中心读取配置了。