美文网首页我爱编程
小白学SpringCloud(三):统一配置中心(config)

小白学SpringCloud(三):统一配置中心(config)

作者: CatalinaX | 来源:发表于2018-06-15 15:52 被阅读0次
    config_logo

    在分布式系统中,每一个功能模块都能拆分成一个独立的服务,一次请求的完成,可能会调用很多个服务协调来完成。如果我们每个服务都有一个独立的配置的话,这样很不方便我们维护。Spring Cloud中为我们提供了一个config组件为我们解决了这个问题,并且更改了配置并不需要我们重启。

    一、Config概述

    同Eureka一样,config也分为server端和client端,我们先来看看server端的原理。这里引用一张廖师兄的图(注:图中的order、product都是客户端)


    config_1

    从这张图我们可以看出,Config Server是以远端Git作为依托(SVN也可以,这里使用Github作为演示),从远端Git仓库中拉取配置并同步到本地Git上。当客户端需要配置的时候就可以从Server端进行配置的拉取。

    二、Config Server配置

    1.创建Config工程
    跟前文一样,我们使用IDEA的Spring Initializr创建我们的Config工程,如图:除了图中圈起来的config Server要勾上,Eureka Discover也要勾上。

    config_2

    2.创建远程仓库
    首先我们先创建一个远程Git仓库,这里以Github为例,这里我已经创建好了一个公开仓库https://github.com/catalinaLi/config_repo
    然后在里面先添加一份配置

    config_3
    3.配置Config工程
    将我们的Config工程注册到Eureka注册中心:
    eureka:
      client:
        serviceUrl:
          defaultZone: http://localhost:8761/eureka/ #服务端地址
    server:
      port: 8764 #客户端端口
    spring:
      application:
        name: config
      cloud:
        config:
          server:
            git:
              uri: https://github.com/catalinaLi/config_repo #config_Server仓库地址
              #如果我们配置的是私有仓库,则还需要远程仓库的账号和密码
              #username: yourusername  
              #password: yourpassword
    env:
      dev   
    

    然后在启动类上添加注解

    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableConfigServer 
    public class ConfigApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ConfigApplication.class, args);
        }
    }
    

    4. Config Server配置
    接下来就可以通过网络来访问我们的配置了,首先启动注册中心Eureka,然后启动我们的Config。这时候我们通过浏览器访问http://localhost:8764/client-dev.yml就可以看到我们的配置了。

    config_5
    这里是Spring Cloud对配置请求的路径做了映射,通常为:
    • /{name}-{profiles}.yml
    • /{label}/{name}-{profiles}.yml

    这两种方式大家可以挑选一个适合你的。
    后缀名也可以不是yml,你可以试试properties,json。Spring Cloud会自动帮你转换。

    三、Config Client配置

    这里我们使用上一篇文章小白SpringCloud(二):服务间的调用中的Client项目来进行改造
    1.添加pom引用
    在FeignClient的pom文件中添加Config Client引用

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-config-client</artifactId>
            </dependency>
    

    2.修改配置文件
    首先我们要把配置文件的名字改为bootstrap.yml,改成这个名字Spring Cloud就会先去Config Server拉取配置。
    然后我们要在bootstrap.yml中定义我们要拉取的文件名称,还记得刚才说的Spring Cloud对请求的路径做的映射方式吗(/{name}-{profiles}.yml)?在这里我们配置nameprofilesConfig项目的名称

    spring:
      application:
        name: client #name
      cloud:
        config:
          discovery:
            enabled: true
            service-id: config #Eureka Config's name
          profile: dev #profiles
    

    这时候,我们的Client就可以正常启动啦,怎么样简单吧。

    二、Config Server的高可用

    统一配置中心的高可用很简单,只需要我们多启动几个相同的实例就好了。Config Client在启动的时候会根据负载均衡去访问Config Server中的某一台.

    还记得导语中说的更改配置可以不用重新启动项目吗?这里需要用到另外一个组件,我们在下篇文章进行讲解。


    本文作者: catalinaLi
    本文链接: http://catalinali.top/2018/config/
    版权声明: 原创文章,有问题请评论中留言。非商业转载请注明作者及出处。

    相关文章

      网友评论

        本文标题:小白学SpringCloud(三):统一配置中心(config)

        本文链接:https://www.haomeiwen.com/subject/eojmeftx.html