yml 配置文件保存到 git 服务器,例如 github.com 或 gitee.comjava
微服务启动时,从服务器获取配置文件git
最后,清空四个项目中的application.yml
文件github
默认配置中心配置优先级高,配置中心配置会覆盖客户端的全部配置,包括命令行参数配置,这样咱们在item-service和order-service中配置的端口号启动参数会无效spring
item-service 启动参数:apache
--service.port=8001
--service.port=8002
order-service 启动参数bootstrap
--service.port=8201
--service.port=8202
能够设置禁止配置中心的配置将客户端配置覆盖掉,这样当咱们从控制中心拉取配置文件后,本地的配置会覆盖拉去来的配置
在四个配置文件中添加下面的配置服务器
spring: ...... cloud: config: override-none: true
springcloud1 工程目录建立本地仓库app
把本地仓库提交推送到gitee远程仓库maven
config 配置中心从 git 下载全部配置文件。
而其余微服务启动时从 config 配置中心获取配置信息。ide
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.2.1.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>cn.tedu</groupId> <artifactId>sp12-config</artifactId> <version>0.0.1-SNAPSHOT</version> <name>sp12-config</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> <spring-cloud.version>Hoxton.RELEASE</spring-cloud.version> </properties> <dependencies> <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> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> <exclusions> <exclusion> <groupId>org.junit.vintage</groupId> <artifactId>junit-vintage-engine</artifactId> </exclusion> </exclusions> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
spring: application: name: config-server cloud: config: server: git: uri: https://gitee.com/Mjp3309/springcloud1 search-paths: config #私有仓库须要配置用户名密码 #username: #password: server: port: 6001 eureka: client: service-url: defaultZone: http://eureka1:2001/eureka,http://eureka2:2002/eureka
@EnableConfigServer
和 @EnableDiscoveryClient
package cn.tedu.sp12; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.cloud.config.server.EnableConfigServer; @EnableConfigServer//启动配置中心服务 @EnableDiscoveryClient @SpringBootApplication public class Sp12ConfigApplication { public static void main(String[] args) { SpringApplication.run(Sp12ConfigApplication.class, args); } }
访问 item-service-dev.yml 能够使用如下形式:
http://localhost:6001/item-service-dev.yml
http://localhost:6001/item-service/dev
测试其余文件
http://localhost:6001/user-service/dev
http://localhost:6001/zuul/dev
http://localhost:6001/order-service/dev
修改如下项目,从配置中心获取配置信息
右键点击项目,编辑起步依赖,添加 config client 依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency>
bootstrap.yml
,引导配置文件,先于 application.yml 加载
spring: cloud: config: discovery: enabled: true service-id: config-server name: item-service profile: dev eureka: client: service-url: defaultZone: http://eureka1:2001/eureka, http://eureka2:2002/eureka
spring: cloud: config: discovery: enabled: true service-id: config-server name: user-service profile: dev eureka: client: service-url: defaultZone: http://eureka1:2001/eureka, http://eureka2:2002/eureka
spring: cloud: config: discovery: enabled: true service-id: config-server name: order-service profile: dev eureka: client: service-url: defaultZone: http://eureka1:2001/eureka, http://eureka2:2002/eureka
spring: cloud: config: discovery: enabled: true service-id: config-server name: zuul profile: dev eureka: client: service-url: defaultZone: http://eureka1:2001/eureka, http://eureka2:2002/eureka
spring cloud 容许运行时动态刷新配置,能够从新从配置中心获取新的配置信息
以 user-service
为例演示配置刷新
user-service 的 pom.xml 中添加 actuator 依赖
右键点击sp03-user-service
项目,编辑起步依赖,添加 actuator 依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>