`

使用spring cloud实现分布式配置管理

 
阅读更多

  《7天学会spring cloud系列》之创建配置管理服务器及实现分布式配置管理应用。

  本文涉及到的项目:

   分布式配置管理应该是分布式系统和微服务应用的第一步。想象一下如果你有几十个服务或应用需要配置,而且每个服务还分为开发、测试、生产等不同维度的配置,那工作量是相当大的,而且还容易出错。如果能把各个应用的配置信息集中管理起来,使用一套机制或系统来管理,那么将极大的提高系统开发的生产效率,同时也会提高系统开发环境和生产环境运行的一致性。

  

  在传统开发中我们往往需要自己开发“配置管理服务器”,你可以使用redis、ldap、zookeeper、db等来存放统一配置信息,然后开发一个管理界面来进行管理。传统的做法没什么问题,和spring cloud所提供的配置管理方案相比,就是前者需要自己开发,而后者直接简单使用现成的组件即可。当然还有很重要的一点,spring 配置管理模块由于是spring boot核心来实现的,因此做了大量的工作,可以把一些启动参数进行外部配置,这在传统的方案中是很难办到的,因为涉及到要改写第三方组件的问题,难度很大。比如web应用的绑定端口,传统应用只能在tomcat配置文件里改,而spring cloud却可以放到远程,类似的还有数据库连接、安全框架配置等。

  要使用spring cloud分布式配置文件总体上分为3个大的步骤,首选你需要创建存放配置文件的仓库,然后创建一个配置文件服务器,该服务器将配置文件信息转化为rest接口数据,然后创建一个应用服务,该服务演示使用分布式配置文件信息。

  1)创建配置文件存放仓库

  Spring cloud使用git或svn存放配置文件,默认情况下使用git,因此你需要安装git私服或者直接使用互联网上的github或者git.oschina,这里推荐使用git.oschina。本文示例使用的是git.oschina,创建好git工程后,也就是文章开头所提到的工程,在此工程再创建一个文件夹cloud-config-repo来存放配置文件。然后创建两个配置文件:

  • cloud-config-dev.properties
  • cloud-config-test.properties

      这两个文件分别对应开发环境和测试环境所需要的配置信息,配置信息如下:

  mysqldb.datasource.url=jdbc\:mysql\://10.0.12.170\:3306/test?useUnicode\=true&characterEncoding\=utf-8

  mysqldb.datasource.username=csst

  mysqldb.datasource.password=csst

  logging.level.org.springframework.web:DEBUG

  配置信息提供了数据库连接参数等,这是因为后面的应用服务中使用到了数据库。

  2)创建spring cloud配置服务器

  配置文件仓库创建好了后,就需要创建配置管理服务器,如前所述该服务器只是将配置文件转换为rest接口服务,不做其它用途。这个服务器的功能也是spring cloud提供的,所以我们只需要引入相关jar包,稍微设置一下即可。创建该服务应用,你需要首选创建一个空的maven工程:

        

  然后在这个工程中增加一个类,命名为:ConfigServerApplication,代码如下:

  @SpringBootApplication

  @EnableConfigServer

  public class ConfigServerApplication {

           public static void main(String[] args) {

            SpringApplication.run(ConfigServerApplication.class, args);

           }

  }

  可以看到,我们只需要用@EnableConfigServer激活该应用为配置文件服务器即可。如此以来该应用启动后就会完成前面提到的功能,即:读取远程配置文件,转换为rest接口服务。

当然,需要配置远程配置文件读取路径,在application.properties中:

  server.port=8888

  spring.cloud.config.server.git.uri=https://git.oschina.net/zhou666/spring-cloud-7simple.git

  spring.cloud.config.server.git.searchPaths=cloud-config-repo

  其中server.port是配置当前web应用绑定8888端口,git.uri指定配置文件所在的git工程路径,searchPaths表示将搜索该文件夹下的配置文件(我们的配置文件放在spring-cloud-7simple这个工程的cloud-config-repo文件夹下)。

  最后,还需要在pom文件中增加配置服务器的相关依赖:

  <dependency>

                     <groupId>org.springframework.cloud</groupId>

                     <artifactId>spring-cloud-config-server</artifactId>

  </dependency>

  如此以来,配置文件服务器就建立好了,可以直接启动了,服务端口是8888,应用只需要绑定改服务器的uri和端口号就可以拿到配置信息了。

  3)  创建一个服务使用该远程配置

  现在可以创建一个服务使用该远程配置了,你可以在远程配置中定义一个简单的自定义信息,比如:

  my.message=helloword

  然后使用前面我们提到的spring boot helloworld应用来读取这个信息。当然,限于篇幅我们直接使用比较复杂的一个服务来演示这个配置管理器的使用,这个服务需要用到数据库访问,数据库访问层我们使用的是mybaits,数据表只有一个,DDL如下:

  CREATE TABLE `user` (

       `id` varchar(50) NOT NULL DEFAULT '',

       `username` varchar(50) DEFAULT NULL,

       PRIMARY KEY (`id`)

  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

  创建好数据表后,回到我们的应用服务:

 

  该服务使用DataSourceProperties封装了mybatis加载配置信息。要拿到远程配置信息,需要设置配置管理服务器地址,该配置设置在:

  bootstrap.properties

  该配置文件信息如下:

  spring.cloud.config.uri=http://127.0.0.1:${config.port:8888}

  spring.cloud.config.name=cloud-config

  spring.cloud.config.profile=${config.profile:dev}

  其中config.uri指定远程加载配置信息的地址,就是前面我们刚建立的配置管理服务器的地址,绑定端口8888,其中config.port:8888,表示如果在命令行提供了config.port参数,我们就用这个端口,否则就用8888端口。config.name表示配置文件名称,查看我们前面创建配置文件,是这个名称:

  cloud-config-dev.properties

  可以分成两部分: {application}- {profile}.properties

  所以我们配置config.name为cloud-config,config.profile为dev,其中dev表示开发配置文件,配置文件仓库里还有一个测试环境的配置文件,切换该配置文件只需要将dev改为test即可,当然这个参数也可以由启动时命令行传入,如:

  java -jar cloud-simple-service-1.0.0.jar --config.profile =test

  此时应用就会加载测试环境下的配置信息。

分享到:
评论

相关推荐

    SpringCloud——分布式配置中心(Spring Cloud Config)

    总结起来,Spring Cloud Config 是一个强大的工具,它使得在分布式系统中管理配置变得更加简单和高效。通过理解其核心概念、配置方式以及如何实现高可用性,我们可以更好地利用它来构建可扩展和灵活的微服务架构。

    SpringCloud基于分布式的租售一体电商平台的设计与实现

    SpringCloud基于分布式的租售一体电商平台的设计与实现 SpringCloud基于分布式的租售一体电商平台的设计与实现 SpringCloud基于分布式的租售一体电商平台的设计与实现 SpringCloud基于分布式的租售一体电商平台的...

    SpringCloud微服务、链路跟踪、分布式配置、分布式网关

    SpringCloud是Java开发人员广泛使用的微服务框架,它提供了一系列工具和组件,帮助开发者构建、部署和管理分布式系统。这个压缩包文件包含了SpringCloud的一些核心功能的示例,包括服务注册与发现、链路跟踪、分布式...

    SpringCloud分布式微服务项目Common通用依赖模块抽离示例代码

    SpringCloud分布式微服务项目Common通用依赖模块抽离示例代码 SpringCloud分布式微服务项目Common通用依赖模块抽离示例代码 SpringCloud分布式微服务项目Common通用依赖模块抽离示例代码 SpringCloud分布式微服务...

    Spring Cloud分布式

    内容丰富详细,带书签目录,界面清楚是不可多得的好资料,对分布式感兴趣的同学们不要错过

    springCloud项目-分布式项目仓库

    springCloud项目-分布式项目仓库springCloud项目-分布式项目仓库springCloud项目-分布式项目仓库springCloud项目-分布式项目仓库springCloud项目-分布式项目仓库springCloud项目-分布式项目仓库springCloud项目-...

    SpringCloud config分布式配置中心.zip

    spring-cloud-config是用来集中管理分布式的配置问题,不同环境不同配置,动态化的配置更新,分环境部署比如dev/test/prod/beta/release,运行期间动态调整配置,不再需要在每个服务部署的机器上编写配置文件,服务...

    spring boot+Spring cloud微服务分布式源码.zip

    Spring Cloud 是一套微服务解决方案,它为开发者提供了在分布式系统(如配置管理、服务发现、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群状态等)中常用模式的快速实现...

    SpringCloud之七 分布式配置中心SpringCloudConfig.pdf

    Spring Cloud Config是Spring Cloud全家桶中的一个组件,它主要用于实现分布式系统中的配置管理。在微服务架构下,系统通常被拆分成许多个小的微服务,每个服务都有自己的配置文件。当配置文件频繁更改或不同服务...

    基于 Spring Cloud 的分布式电商项目

    基于 Spring Cloud 的分布式电商项目,该项目使用分库设计方案,不同的模块依赖不同的数据库实例。后台登陆采用 Oauth 2.0 授权,支持密码登陆、授权码登陆、短信验证码登陆、注册中心与配置中心已使用 alibaba naco...

    springcloud入门代码基于Spring Cloud实现的分布式配置中心源代码

    在深入研究源代码`springcloud-chapter07-master`时,你可以学习到如何设置Config Server和Config Client,以及如何在微服务之间进行通信以获取配置。这将涉及到Spring Boot的启动类配置、Spring Cloud的相关依赖、...

    springCloud分布式配置中心

    本demo springCloud版本为1.5.9,...本项目使用本地分布式配置(非git远程配置),启动顺序为服务注册中心(discovery)、配置中心(confugure)、微服务(micro-server),配置文件ip需修改为你自己的ip或localhost。

    毕业设计基于SpringCloud微服务分布式链路追踪项目源码.zip

    毕业设计基于SpringCloud微服务分布式链路追踪系统源码 追踪实现 使用zipkin+sleuth实现 这个是比较成熟的分布式链路追踪实现方案 拦截器自定义实现 基于Google Dapper 论文,进行自定义实现。 原理: traceId :...

    基于SpringCloud的分布式的物联网(IOT)平台.zip

    一个基于Spring Cloud的开源的、分布式的物联网(IOT)平台,用于快速开发物联网项目和管理物联设备,是一整套物联系统解决方案。 一个基于Spring Cloud的开源的、分布式的物联网(IOT)平台,用于快速开发物联网项目和...

    SpringCloud基于SpringBoot 分布式服务实现

    SpringCloud基于SpringBoot 分布式服务实现,暂时实现了服务发现,rabbin和fegin两种调用方式,负载均衡、只能路由后续会持续更新代码(自己学习分布式服务架构,之前有dubbo开发经验,想去学习Spring全家桶)

    SpringCloud分布式微服务项目搭建构造父子模块依赖与实现服务提供者与消费者示例

    SpringCloud分布式微服务项目搭建构造父子模块依赖与实现服务提供者与消费者示例 SpringCloud分布式微服务项目搭建构造父子模块依赖与实现服务提供者与消费者示例 SpringCloud分布式微服务项目搭建构造父子模块依赖...

    SpringCloud微服务分布式架构开发实战-50000-05-作业及参考答案.rar.rar

    SpringCloud是Java领域中广泛使用的微服务开发工具集,它提供了众多服务发现、配置管理、负载均衡、熔断机制等组件,使得开发者能够轻松构建分布式系统。 首先,我们需要了解SpringCloud的核心组件。Eureka是服务...

    基于springcloud框架的分布式架构网上商城毕业设计(源码+开发说明+演示视频).zip

    基于springcloud框架的分布式架构网上商城毕业设计(源码+开发说明+演示视频) 【项目技术】 开发语言:Java 框架:springcloud 架构:B/S 数据库:mysql 【实现功能】 1.系统功能模块 分布式架构网上商城,在系统...

    基于springcloud的分布式网上商城系统源码.zip

    SpringCloud是基于Spring Boot的微服务开发工具集,它为开发者提供了在分布式系统(如配置管理、服务发现、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群状态)中快速构建...

    尚硅谷SpringCloud第2季2020版.mmap

    SpringCloud Config 分布式配置中心 SpringCloud Bus 消息总线 SpringCloud Stream 消息驱动 SpringCloud Sleuth 分布式请求链路跟踪 SpringCloud Alibaba入门简介 SpringCloud Alibaba Nacos 服务注册和配置...

Global site tag (gtag.js) - Google Analytics