建议使用以下浏览器,以获得最佳体验。 IE 9.0+以上版本 Chrome 31+ 谷歌浏览器 Firefox 30+ 火狐浏览器
请选择 进入手机版 | 继续访问电脑版
设置昵称

在此一键设置昵称,即可参与社区互动!

确定
我再想想
选择版块
标签
您还可以添加5个标签
  • 没有搜索到和“关键字”相关的标签
  • 云产品
  • 解决方案
  • 技术领域
  • 通用技术
  • 平台功能
取消
发表于2019年08月28日 11:43:57 3281 1
直达本楼层的链接
楼主
显示全部楼层
[专家内容专区] 方志朋-SpringCloud系列:spring cloud config将配置存储在数据库中

原创作者:方志朋

方志朋简介:SpringCloud中国社区联合创始人,博客访问量突破一千万,爱好开源,热爱分享,活跃于各大社区,保持着非常强的学习驱动力,终身学习践行者,终身学习受益者。目前就职于国内某家知名互联网保险公司,担任DEVOPS工程师,对微服务领域和持续集成领域研究较深,精通微服务框架Spring

Cloud

 

Spring Cloud Config Server最常见是将配置文件放在本地或者远程Git仓库,放在本地是将将所有的配置文件统一写在Config Server工程目录下,如果需要修改配置,需要重启config server;放在Git仓库,是将配置统一放在Git仓库,可以利用Git仓库的版本控制。本文将介绍使用另外一种方式存放配置信息,即将配置存放在Mysql中。

整个流程:Config Sever暴露Http API接口,Config Client 通过调用Config SeverHttp API接口来读取配置Config Server的配置信息,Config Server从数据中读取具体的应用的配置。流程图如下:

图片 1.png

案例实战

在本案例中需要由2个工程,分为config-serverconfig-client,其中config-server工程需要连接Mysql数据库,读取配置;config-client则在启动的时候从config-server工程读取。本案例Spring Cloud版本为Greenwich.RELEASESpring Boot版本为2.1.0.RELEASE

工程

描述

config-server

端口8769,从数据库中读取配置

config-client

端口8083,从config-server读取配置

搭建config-server工程

创建工程config-server,在工程的pom文件引入config-server的起步依赖,mysql的连接器,jdbc的起步依赖,代码如下:

1.  <dependency>

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

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

4.  </dependency>

5.  <dependency>

6.      <groupId>mysql</groupId>

7.      <artifactId>mysql-connector-java</artifactId>

8.  </dependency>

9.  <dependency>

10.      <groupId>org.springframework.boot</groupId>

11.      <artifactId>spring-boot-starter-jdbc</artifactId>

12.  </dependency>

在工程的配置文件application.yml下做以下的配置:

1.  spring:

2.    profiles:

3.       active: jdbc

4.    application:

5.       name: config-jdbc-server

6.    datasource:

7.       url: jdbc:mysql://127.0.0.1:3306/config-jdbc?useUnicode=true&characterEncoding=utf8&characterSetResults=utf8&serverTimezone=GMT%2B8

8.       username: root

9.       password: 123456

10.       driver-class-name: com.mysql.jdbc.Driver

11.    cloud:

12.       config:

13.         label: master

14.         server:

15.           jdbc: true

16.  server:

17.    port: 8769

18.  spring.cloud.config.server.jdbc.sql: SELECT key1, value1 fromconfig_properties whereAPPLICATION=? andPROFILE=? andLABEL=?

其中,spring.profiles.activespring读取的配置文件名,从数据库中读取,必须为jdbcspring.datasource配置了数据库相关的信息,spring.cloud.config.label读取的配置的分支,这个需要在数据库中数据对应。spring.cloud.config.server.jdbc.sql为查询数据库的sql语句,该语句的字段必须与数据库的表字段一致。

在程序的启动文件ConfigServerApplication加上@EnableConfigServer注解,开启ConfigServer的功能,代码如下:

1.  @SpringBootApplication

2.  @EnableConfigServer

3.  publicclassConfigServerApplication{

4.    

5.      publicstaticvoidmain(String[] args) {

6.          SpringApplication.run(ConfigServerApplication.class, args);

7.      }

8.  }

初始化数据库

由于Config-server需要从数据库中读取,所以读者需要先安装MySQL数据库,安装成功后,创建config-jdbc数据库,数据库编码为utf-8,然后在config-jdbc数据库下,执行以下的数据库脚本:

1.  CREATE TABLE `config_properties`(

2.    `id`bigint(20) NOT NULL AUTO_INCREMENT,

3.    `key1`varchar(50) COLLATE utf8_bin NOT NULL,

4.    `value1`varchar(500) COLLATE utf8_bin DEFAULT NULL,

5.    `application`varchar(50) COLLATE utf8_bin NOT NULL,

6.    `profile`varchar(50) COLLATE utf8_bin NOT NULL,

7.    `label`varchar(50) COLLATE utf8_bin DEFAULT NULL,

8.    PRIMARY KEY (`id`)

9.  ) ENGINE=InnoDBAUTO_INCREMENT=3DEFAULT CHARSET=utf8 COLLATE=utf8_bin

其中key1字段为配置的key,value1字段为配置的值,application字段对应于应用名,profile对应于环境,label对应于读取的分支,一般为master

**数据config-client 2条数据,包括server.portfoo两个配置,具体数据库脚本如下:

1.  insert into`config_properties`(`id``key1``value1``application``profile``label`) values('1','server.port','8083','config-client','dev','master');

2.  insert into`config_properties`(`id``key1``value1``application``profile``label`) values('2','foo','bar-jdbc','config-client','dev','master');

搭建config-client

config-client工程的pom文件,引入webconfig的起步依赖,代码如下:

1.  <dependency>

2.      <groupId>org.springframework.boot</groupId>

3.      <artifactId>spring-boot-starter-web</artifactId>

4.  </dependency>

5.    

6.  <dependency>

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

8.      <artifactId>spring-cloud-starter-config</artifactId>

9.  </dependency>

在程序的启动配置文件bootstrap.yml做程序的相关配置,一定要是bootstrap.yml,不可以是application.ymlbootstrap.yml的读取优先级更高,配置如下:

1.  spring:

2.    application:

3.      name: config-client

4.    cloud:

5.      config:

6.        uri: http://localhost:8769

7.        fail-fast: true

8.    profiles:

9.      active: dev

其中spring.cloud.config.uri配置的config-server的地址,spring.cloud.config.fail-fast配置的是读取配置失败后,执行快速失败。spring.profiles.active配置的是spring读取配置文件的环境。

在程序的启动文件ConfigClientApplication,写一个RestAPI,读取配置文件的foo配置,返回给浏览器,代码如下:

1.  @SpringBootApplication

2.  @RestController

3.  publicclassConfigClientApplication{

4.    

5.      publicstaticvoidmain(String[] args) {

6.          SpringApplication.run(ConfigClientApplication.class, args);

7.      }

8.    

9.      @Value("${foo}")

10.      Stringfoo;

11.      @RequestMapping(value = "/foo")

12.      publicStringhi(){

13.          returnfoo;

14.      }

15.  }

依次启动2个工程,其中config-client的启动端口为8083,这个是在数据库中的,可见config-clientconfig-server中读取了配置。在浏览器**http://localhost:8083/foo,浏览器显示bar-jdbc,这个是在数据库中的,可见config-clientconfig-server中读取了配置。

参考资料

https://cloud.spring.io/spring-cloud-config/single/spring-cloud-config.html#jdbcbackend

源码下载

https://github.com/forezp/SpringCloudLearning/tree/master/chapter10-5-jdbc


原创作者:方志朋

方志朋简介:SpringCloud中国社区联合创始人,博客访问量突破一千万,爱好开源,热爱分享,活跃于各大社区,保持着非常强的学习驱动力,终身学习践行者,终身学习受益者。目前就职于国内某家知名互联网保险公司,担任DEVOPS工程师,对微服务领域和持续集成领域研究较深,精通微服务框架SpringCloud


举报
分享

分享文章到朋友圈

分享文章到微博

建赟

发帖: 673粉丝: 48

发消息 + 关注

发表于2019年09月27日 14:43:23
直达本楼层的链接
沙发
显示全部楼层

学习一下

点赞 评论 引用 举报

游客

富文本
Markdown
您需要登录后才可以回帖 登录 | 立即注册