前言
在上一篇,通过dubbo的版本号控制,我们实现了一个服务的简单的灰度发布过程,在真实的项目环境中,灰度发布的应用场景是很多的,服务接口存在灰度的需求,本篇再介绍另一种比较常见的灰度需求场景,即配置文件的灰度发布
基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能
配置文件简介
如今,微服务架构盛行下,不管是互联网大厂,还是规模较小的团队,都有一套自己的中央配置文件管理中心,各个微服务模块都能接入中央配置文件,进行统一的使用,现如今,配置中心的技术选择也是非常丰富的,比如springcloud技术栈下的springcloud-config
,springcloud-alibaba
下自研的nacos,传统的配置中心disconf,携程出品的apollo等,都是不错的选择
不管外观如何变化,他们的作用都是相同的,那就是统一管理微服务的配置,起到统一管理,统一维护,统一调度的作用
在这种形势下,实际的业务中就出现了这么一种情况,配置管理中心可能存在针对不同环境,比如 dev,test,prod等环境各自的一套配置文件,但实际上,这还是无法满足某些场景下的要求的
举例来说,像上一篇介绍的,服务接口需要做到灰度使用,利用不同的版本号进行控制,从而达到新功能和之前稳定版本功能做到动态切换的效果,而配置文件是控制程序中某些业务的关键信息,同样需要做到类似的功能,这种情况下该如何实现呢?
在一些开源的配置管理技术框架中,它们为了满足这样的需求就实现了类似的灰度发布的功能,本篇将介绍如何利用apollo实现配置文件的灰度发布
基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能
apollo简介与快速搭建
关于apollo的介绍,网上有大量的参考和学习资料,主要想说的是,apollo是一款非常好用的配置管理工具,应用于各个大中小型互联网公司,可以无缝整合到很多java框架下,代码侵入性低,而配置文件修改后实时生效是它的一大亮点
快速搭建过程
本篇基于centos7或者阿里云
1、安装java环境
安装JDK1.8及以上(省略)
2、安装mysql
安装mysql5.7及以上(省略)
3、github下载源码包
- 下载Release版本:https://github.com/ctripcorp/apollo/releases
其主要的目录文件如上图所示,首先,在mysql中执行下sql目录下的两个sql脚本,apollo的运行依赖数据库
4、将解压后的文件上传至服务器
修改demo.sh,主要修改连接数据库信息
修改内容如下,主要将数据库连接信息配置成自己的数据库IP即可
修改完毕后,启动apollo,只需要执行命令: sh demo.sh start
即可,等待服务启动完毕之后,浏览器访问:http://IP:8070
,然后输入默认登录用户名和密码 apollo/admin
即可进入apollo主页面
关于apollo的具体使用本文不做过多赘述,有兴趣的同学可以深入学习
5、apollo创建一个项目
为了后文使用演示,这里快速创建一个app,和一个namespace,创建也非常简单,只需要点击 "创建应用"即可
默认是application应用,当然可以通过创建新的namespace的方式新建一个新的namespace,这个是为了各自的项目管理自身的配置文件进行使用,为了方便测试,这里我们在application应用下,创建了一个叫做dubbo的namespace,随机添加几个配置文件,即key/value
的数据
友情提醒:注意appId,工程中后面有使用
以上的准备工作到此结束
演示工程步骤
提前准备一个springboot工程
1、添加核心依赖
主要包括springboot和apollo客户端连接依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.2.1.RELEASE</version> </dependency> <dependency> <groupId>com.ctrip.framework.apollo</groupId> <artifactId>apollo-client</artifactId> <version>1.5.1</version> </dependency>
2、配置文件
server: port: 8001 #连接apollo的配置 app: id: provider apollo: meta: http://IP:8080 bootstrap: enabled: true namespaces: dubbo