接上篇文章(config的服务端):https://blog.csdn.net/qq_33333654/article/details/103081664
demo代码地址:https://download.csdn.net/download/qq_33333654/12014918
环境什么的跟上一篇一样。
首先启动注册中心,具体可参考我之前的注册中心高可用博客:
https://blog.csdn.net/qq_33333654/article/details/102636388
然后启动上一篇中的server项目。
接下来创建一个普通的springboot项目 spring-cloud-config-client
先修改pom文件依赖:
<?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>1.5.3.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>spirng-cloud-config-client</artifactId> <version>0.0.1-SNAPSHOT</version> <name>spirng-cloud-config-client</name> <description>Demo project for Spring Boot</description> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <spring-cloud.version>Dalston.RELEASE</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</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>
相比于上篇新增了依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
作为一个web项目启动。
特别注意Config的依赖变了 :
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency>
上一篇中的是带有一个-server的,这里没有。我第一次弄 的时候没注意,一直启动报错,后来检查才看到。
接下来修改配置文件:
server: port: 9021 eureka: client: service-url: defaultZone: http://peer1:8000/eureka/,http://peer2:8001/eureka/,http://peer3:8002/eureka/ spring: application: name: spring-cloud-config-client
这是一个正常的注册中心配置,那么如何调用config服务端呢?
在application.yml文件的同级目录下创建一个:bootstrap.yml文件。
推荐一篇两者个配置文件的区别的文章: https://www.cnblogs.com/hankuikui/p/10496178.html
简单讲就是bootstrap优先于application加载。
下面是bootstrap的配置:
spring: cloud: config: #配置中心的地址 uri: http://localhost:9020/ #对应的是配置文件规则中的{application}部分 name: native #对应的是配置文件规则中的{profile}部分,可以是多个,用逗号隔开。 profile: mysql #对应的是配置文件规则中的{label}部分 lable: master
uri就是server的地址,name对应了server项目中的profiles下的配置的active, profile对应了要读取的文件,可以读取多个。
常见配置规则:
- spring.application.name:对应{application}部分
- spring.cloud.config.profile:对应{profile}部分
- spring.cloud.config.label:对应git的分支。如果配置中心使用的是本地存储,则该参数无用
- spring.cloud.config.uri:配置中心的具体地址
- spring.cloud.config.discovery.service-id:指定配置中心的service-id,便于扩展为高可用配置集群。
特别注意:上面这些与spring-cloud相关的属性必须配置在bootstrap.yml中,config部分内容才能被正确加载。因为config的相关配置会先于application.yml,而bootstrap.yml的加载也是先于application.yml。
接下来就是创建一个控制器进行调用:
package com.example.spirngcloudconfigclient.web; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; /** * @ProjectName: spirng-cloud-config-client * @Package: com.example.spirngcloudconfigclient.web * @ClassName: HelloController * @Author: MC * @Description: ${description} * @Date: 2019/11/15 0015 11:45 * @Version: 1.0 */ @RestController public class HelloController { @Value("${native.hello}") private String hello; @RequestMapping("/hello") public String from() { return this.hello; } }
@Value注解读取的就是配置文件中的内容。
接下来启动项目。注意:启动类只需要@SpringBootApplicatio一个注解。
访问:http://localhost:9021/hello
结果如下:
OK注册中心客户端调用完成。