文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

一篇带给你 Apollo 配置中心详细教程

2024-12-02 21:18

关注

服务端基于Spring Boot和Spring Cloud开发,打包后可以直接运行,不需要额外安装Tomcat等应用容器。

Java客户端 不依赖任何框架,能够运行于所有Java运行时环境,同时对Spring/Spring Boot环境也有较好的支持。

.Net客户端 不依赖任何框架,能够运行于所有.Net运行时环境。

官方 GitHub: https://github.com/ctripcorp/apollo

官方 Gitee: https://gitee.com/nobodyiam/apollo

二、安装部署

2.1 环境准备

java:JDK 1.8.+

maven: 3.3.9

mysql: 版本要求(5.6.5+)

查看数据库版本:SHOW VARIABLES WHERE Variable_name = 'version';

Apollo服务端:1.9+

Apollo客户端:1.7+

2.2 安装包下载

源码下载 从(Apollo-github[1]) 下载最新的源码,也可以通过 git 命令下载到本地

git clone https://github.com/ctripcorp/apollo

下载安装包 地址:https://github.com/ctripcorp/apollo/releases

注意: 本文中使用的方式为 1.源码下载,进行演示。

2.3 创建数据库

Apollo 服务端总共需要两个数据库:ApolloPortalDB和 ApolloConfigDB

我们可以在下载的源码包里面找到,文件目录为:apollo\scripts\sql,路径如下图所示:

或者通过下载地址来获取SQL

ApolloPortalDB

SQL下载地址:https://github.com/ctripcorp/apollo/tree/master/scripts/sql 导入成功后,验证SQL:select * from `ApolloPortalDB`.`ServerConfig`;

ApolloConfigDB

SQL下载地址:https://github.com/ctripcorp/apollo/tree/master/scripts/sql 导入成功后,验证SQL:select * from `ApolloConfigDB`.`ServerConfig`;

2.4 服务端配置调整(可选项)

ApolloPortalDB库配置

操作表:ServerConfig

ApolloConfigDB库配置

操作表:ServerConfig

5 打开工程

将下载下来的 Apollo 源码导入 idea 中,需要关注的项目主要是下面这三个:

我们找到 /apollo/scripts/build.bat的文件(Linux 是 bulid.sh)

修改数据库配置信息,注意这是两个库(ApolloPortalDB和 ApolloConfigDB):

  1. rem apollo config db info(这个是ApolloConfigDB库) 
  2. set pollo_config_db_url="jdbc:mysql://localhost:3306/ApolloConfigDB?serverTimezone=UTC&characterEncoding=utf-8" 
  3. set apollo_config_db_username="root" 
  4. set apollo_config_db_password="123456" 
  5.  
  6. rem apollo portal db info(这个是ApolloPortalDB库) 
  7. set pollo_portal_db_url="jdbc:mysql://localhost:3306/ApolloPortalDB?serverTimezone=UTC&characterEncoding=utf-8" 
  8. set apollo_portal_db_username="root" 
  9. set apollo_portal_db_password="123456" 
  10.  
  11. rem meta server url, different environments should have different meta server addresses 
  12. rem 配置各环境meta service地址(configservice部署的地址) 
  13. rem 后面版本也是可以再运行时指定: -apollo.meta=http://192.168.*.*:8080 
  14. set dev_meta="http://localhost:8080" 
  15. set fat_meta="http://someIp:8080" 
  16. set uat_meta="http://anotherIp:8080" 
  17. set pro_meta="http://yetAnotherIp:8080" 

注意: 数据库连接,需要添加serverTimezone=UTC否则可能会报错

修改完上面的配置以后,我们就可以执行build.bat批处理命令进行编译打包。在windows 运行build.bat文件,如果是LInux 运行 build.sh

第一次会执行比较慢,需要下载Maven jar

打包成功后,我们找到 apollo-configservice、apollo-adminservice、apollo-portal下target 目录,找到已经打好的三个jar包,copy 出来放到一个单独的目录,方便我们启动。

如下图所示:

启动顺序为:apollo-configservice > apollo-adminservice > apollo-portal三个服务。

启动脚本,放到记事本,修改后缀名为 .bat就可以一键启动三个服务了。

  1. @echo off 
  2. start cmd /c "java -jar apollo-configservice-1.10.0-SNAPSHOT.jar"                                       
  3. start cmd /c "java -jar apollo-adminservice-1.10.0-SNAPSHOT.jar"                                       
  4. start cmd /c "java -jar apollo-portal-1.10.0-SNAPSHOT.jar" 
  5. spause                   // 防止运行完毕后直接关闭界面 

全部启动成功之后,打开浏览器输入:http://localhost:8070/,看到 Apollo 登录页面说明启动成功。

用户名密码: apollo/admin

输入 http://localhost:8080 ,如果出现eureka 的管理界面,说明服务启动正常。

三、客户端使用

客户端使用指南[2]

3.1 导入jar包

  1.  
  2.       com.ctrip.framework.apollo 
  3.       apollo-client 
  4.       1.7.0 
  5.    
  6.       数据库jar--> 
  7.    
  8.       mysql 
  9.       mysql-connector-java 
  10.       runtime 
  11.    
  12.    
  13.       org.springframework.boot 
  14.       spring-boot-starter-data-jpa 
  15.       1.5.9.RELEASE 
  16.    

3.2 发布配置

创建应用

AppId:001

AppId:mxn-front-gateway

AppId是应用的身份信息,是从服务端获取配置的一个重要信息。

AppId:001的配置内容

AppId:mxn-front-gateway的配置内容

上面的两张图,就是我们Apollo配置中心的详细配置页面

3.3 操作配置项

输入配置内容 

3.4 发布配置

添加发布信息

四、Spring Boot 集成 Apollo

在Spring Boot中使用 apollo 配置比较方便,我们只需要在对应的配置(yml或者properties)中设置 apollo的(appid和meta)以及命名空间就行。

application.yml 配置

  1. app: 
  2.   id: 001 
  3. apollo: 
  4.   meta: http://localhost:8080 
  5.   bootstrap: 
  6.     enabled: true 
  7.     namespaces: dev.yml,test.properties 

Spring Boot 启动类,添加 @EnableApolloConfig

  1. @SpringBootApplication 
  2. @EnableApolloConfig 
  3. public class ApolloMxnApplication { 
  4.  
  5.     public static void main(String[] args) { 
  6.         SpringApplication.run(ApolloMxnApplication.class, args); 
  7.     } 
  8.  

测试类,实时获取配置信息

  1. import org.springframework.beans.factory.annotation.Value; 
  2. import org.springframework.web.bind.annotation.RequestMapping; 
  3. import org.springframework.web.bind.annotation.RestController; 
  4.  
  5.  
  6. @RestController 
  7. public class TestController { 
  8.  
  9.     @Value(value = "${mxn.name}"
  10.     private String name
  11.  
  12.     @RequestMapping("test"
  13.     public String test(){ 
  14.         return "hello world "+name
  15.     } 
  16.  

这样我们就可以 从 meta 中 拉取两个命名空间(apollo-adminservice和apollo-configservice)的配置了Apollo

五、实现配置热加载

创建配置热加载实现类

  1. import com.ctrip.framework.apollo.core.ConfigConsts; 
  2. import com.ctrip.framework.apollo.model.ConfigChangeEvent; 
  3. import com.ctrip.framework.apollo.spring.annotation.ApolloConfigChangeListener; 
  4. import lombok.extern.slf4j.Slf4j; 
  5. import org.springframework.beans.factory.annotation.Autowired; 
  6. import org.springframework.boot.autoconfigure.jdbc.DataSourceProperties; 
  7. import org.springframework.boot.context.properties.EnableConfigurationProperties; 
  8. import org.springframework.cloud.context.config.annotation.RefreshScope; 
  9. import org.springframework.context.ApplicationContext; 
  10. import org.springframework.context.annotation.Bean; 
  11. import org.springframework.context.annotation.Configuration; 
  12.  
  13. import javax.sql.DataSource; 
  14.  
  15.  
  16. @Configuration 
  17. @EnableConfigurationProperties(DataSourceProperties.class) 
  18. @Slf4j 
  19. public class ConfigHotLoad { 
  20.  
  21.     @RefreshScope 
  22.     @Bean("dataSource_Bean"
  23.     public DataSource dataSource(DataSourceProperties dataSourceProperties){ 
  24.         return dataSourceProperties.initializeDataSourceBuilder().build(); 
  25.     } 
  26.  
  27.     @Autowired 
  28.     private ApplicationContext applicationContext; 
  29.  
  30.     @Autowired 
  31.     private org.springframework.cloud.context.scope.refresh.RefreshScope refreshScope; 
  32.  
  33.      
  34.     @ApolloConfigChangeListener(value = {ConfigConsts.NAMESPACE_APPLICATION,"dev"},interestedKeyPrefixes = {"spring.datasource"}) 
  35.     public void onChange(ConfigChangeEvent configChangeEvent){ 
  36.         // 重新编译DataSource 初始化bean 
  37.         refreshScope.refresh("dataSource_Bean"); 
  38.         log.info("Apollo config changed {}",applicationContext.getBean(DataSourceProperties.class).toString()); 
  39.  
  40.     } 
  41.  

我们 输入地址 http://localhost:你的端口/test[3] 就可以看到,对应的配置名字,然后修改apollo里面的信息,发布后,再不启动项目的情况下,就可以更新我们的配置信息了

Apollo 本地缓存

Linux:/opt/data/{appId}/config-cache Windows:C:\opt\data{appId}\config-cache

六、什么是 Apollo

官方案例: 使用案例Demo可以参考Apollo使用场景和示例代码[4]。

6.1 诞生背景

随着程序功能的日益复杂,程序的配置日益增多:各种功能的开关、参数的配置、服务器的地址……

对程序配置的期望值也越来越高:配置修改后实时生效,灰度发布,分环境、分集群管理配置,完善的权限、审核机制……

在这样的大环境下,传统的通过配置文件、数据库等方式已经越来越无法满足开发人员对配置管理的需求。

Apollo配置中心应运而生!

6.2 Apollo 说明

Apollo(阿波罗)是携程框架部门研发的开源配置管理中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性。

Apollo支持4个维度管理Key-Value格式的配置:

application (应用)

environment (环境)

cluster (集群)

namespace (命名空间)

同时,Apollo基于开源模式开发,开源地址:https://github.com/ctripcorp/apollo

6.3 基础模型

Apollo的基础模型:

用户在配置中心对配置进行修改并发布

配置中心通知Apollo客户端有配置更新

Apollo客户端从配置中心拉取最新的配置、更新本地配置并通知到应用

七、Apollo特性

由于配置的特殊性,所以Apollo 从开始设计到完善就立志作为一个有治理能力的配置中心平台,Apollo的特性主要体现在以下几个方面

Apollo提供了一个统一界面集中式管理不同环境(environment)、不同集群(cluster)、不同命名空间(namespace)的配置。

同一份代码部署在不同的集群,可以有不同的配置,比如zookeeper的地址等

通过命名空间(namespace)可以很方便地支持多个不同应用共享同一份配置,同时还允许应用对共享的配置进行覆盖

用户在Apollo修改完配置并发布后,客户端能实时(1秒)接收到最新的配置,并通知到应用程序

所有的配置发布都有版本概念,从而可以方便地支持配置的回滚

支持配置的灰度发布,比如点了发布后,只对部分应用实例生效,等观察一段时间没问题后再推给所有应用实例

应用和配置的管理都有完善的权限管理机制,对配置的管理还分为了编辑和发布两个环节,从而减少人为的错误。

所有的操作都有审计日志,可以方便地追踪问题

可以在界面上方便地看到配置在被哪些实例使用

提供了Java和.Net的原生客户端,方便应用集成

支持Spring Placeholder, Annotation和Spring Boot的ConfigurationProperties,方便应用使用(需要Spring 3.1.1+)

同时提供了Http接口,非Java和.Net应用也可以方便地使用

Apollo自身提供了比较完善的统一配置管理界面,支持多环境、多数据中心配置管理、权限、流程治理等特性。不过Apollo出于通用性考虑,不会对配置的修改做过多限制,只要符合基本的格式就能保存,不会针对不同的配置值进行针对性的校验,如数据库用户名、密码,Redis服务地址等

对于这类应用配置,Apollo支持应用方通过开放平台API在Apollo进行配置的修改 和发布,并且具备完善的授权和权限控制

配置中心作为基础服务,可用性要求非常高,这就要求Apollo对外部依赖尽可能地少

目前唯一的外部依赖是MySQL,所以部署非常简单,只要安装好Java和MySQL就可以让Apollo跑起来

Apollo还提供了打包脚本,一键就可以生成所有需要的安装包,并且支持自定义运行时参数

八、Apollo原理

上图简要描述了Apollo客户端的实现原理:

客户端和服务端保持了一个长连接,从而能第一时间获得配置更新的推送。

客户端还会定时从Apollo配置中心服务端拉取应用的最新配置。

客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存中

客户端会把从服务端获取到的配置在本地文件系统缓存一份

应用程序从Apollo客户端获取最新的配置、订阅配置更新通知

九、自定义Cluster

9.1 新建Cluster

点击后就进入到集群添加页面,一般情况下可以按照数据中心来划分集群 不过也支持自定义集群,比如可以为A机房的某一台机器和B机房的某一台机创建一个集群,使用一套配置。

Apollo会默认使用应用实例所在的数据中心作为cluster,所以如果两者一致的话,不需要额外配置。

如果cluster和数据中心不一致的话,那么就需要通过System Property方式来指定运行时cluster:

十、配置获取规则

在有了cluster概念后,配置的规则就显得重要了。比如应用部署在A机房,但是并没有在Apollo新建cluster,这个时候Apollo的行为是怎样的?或者在运行时指定了cluster=SomeCluster,但是并没有在Apollo新建cluster,这个时候Apollo的行为是怎样的?

10.1 应用自身配置的获取规则

当应用使用下面的语句获取配置时,我们称之为获取应用自身的配置,也就是应用自身的application namespace的配置。

Config config = ConfigService.getAppConfig();

对这种情况的配置获取规则,简而言之如下:

首先查找运行时cluster的配置(通过apollo.cluster指定)

如果没有找到,则查找数据中心cluster的配置

如果还是没有找到,则返回默认cluster的配置

图示如下:

所以如果应用部署在A数据中心,但是用户没有在Apollo创建cluster,那么获取的配置就是默认cluster(default)的。

如果应用部署在A数据中心,同时在运行时指定了SomeCluster,但是没有在Apollo创建cluster,那么获取的配置就是A数据中心cluster的配置,如果A数据中心cluster没有配置的话,那么获取的配置就是默认cluster(default)的。

十一、总体设计

上图简要描述了Apollo的总体设计,我们可以从下往上看:

十二、总结

到这里Apollo,就讲解完了,其实Apollo 可以理解成一个好用的配置管理中心,这里小农也是了解了一点皮毛,大家有不懂的地方,欢迎留言。

我是牧小农,怕什么真理无穷,进一步有进一步的欢喜,大家加油~

 

来源:牧小农内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯