配置服务是为了解决项目配置分散,不便于集中管理的问题,传统多模块服务中,一旦配置发生更改,我们需要在相关项目中做修改,然后部署,如果配置文件统一在一个地方管理,那么修改起来就方便多了。
我们这里配置服务在config项目中,config项目即作为配置服务,需要依赖spring-cloud-config-server,同时,它也作为一个eureka客户端程序,需要注册在eureka server上,因此也需要依赖spring-cloud-starter-netflix-eureka-client。
我们根据上面的分析,我们在pom.xml文件中配置以下依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
编写ConfigApplication.java应用启动程序:
package com.xxx.config;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@SpringBootApplication
@EnableEurekaClient
@EnableConfigServer
public class ConfigApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigApplication.class,args);
}
}
@EnableEurekaClient开启作为eureka server的客户端的支持,@EnableConfigServer开启配置服务器的支持。
这里需要说明一下,我们的配置文件,springcloud应用提供使用bootstrap.yml(或者bootstrap.properties)负责从外部资源加载配置属性,因此,我们config以及以后的项目gateway,feign,ribbon,monitor等均使用两个配置文件,一个是application.yml,一个是bootstrap.yml,在config项目中,application.yml配置文件的内容是:
server:
port: 8888
spring:
cloud:
config:
server:
native:
search-locations: classpath:/config
spring.cloud.config.server.native.search-locations: classpath:/config 表示配置其他应用所需的配置文件的位置位于类路径下的config目录下。如下所示:
这里配置的两个文件分别是给后面feign、ribbon项目使用的,命名规则是根据所在项目spring.application.name中指定的名字来命名的。
bootstrap.yml配置文件的内容是:
spring:
application:
name: config
profiles:
active: native
eureka:
instance:
metadata-map:
instanceId: ${spring.application.name}:${random.value}
non-secure-port: ${server.port:8888}
client:
service-url:
defaultZone: http://localhost:8761/eureka/
- spring.application.name: config指定应用名称为config,这个名字会在服务发现列表中体现出来。
- spring.profiles.active: native表示配置服务器使用的是本地配置,默认是git。
- eureka.instance.metadata-map.instanceId: ${spring.application.name}:${random.value}表示在eureka server中的实例ID。
- eureka.instance.non-secure-port: ${server.port:8888} 非ssl端口,默认使用环境变量server.port的值。
- eureka.client.service-url.defaultZone: http://localhost:8761/eureka/ 指定eureka server的地址。
配置服务是用来做配置管理的,如果不是特别的要求,配置分别写在各自项目的配置文件里也不是不可以,就是又回到了本文前面提到的修改的问题。
启动配置服务,我们可以在发现服务管理页面上查看,会多了一个实例。
这里我们给出后续要用到的两个配置文件的内容:
feign.yml
spring:
jpa:
database: POSTGRESQL
datasource:
driver-class-name: org.postgresql.Driver
username: postgres
password:
url: jdbc:postgresql://localhost:5432/mydb
platform: postgres
ribbon.yml
springcloud:
message: this is a message from config server
如果本文节奏上跟不上,我们可以返回去,看springcloud入门示例之服务发现。