成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一篇帶給你 Apollo 配置中心詳細教程

開發 后端
Apollo(阿波羅)是攜程框架部門研發的分布式配置中心,能夠集中化管理應用不同環境、不同集群的配置,配置修改后能夠實時推送到應用端,并且具備規范的權限、流程治理等特性,適用于微服務配置管理場景。

[[424672]]

一、簡介

Apollo(阿波羅)是攜程框架部門研發的分布式配置中心,能夠集中化管理應用不同環境、不同集群的配置,配置修改后能夠實時推送到應用端,并且具備規范的權限、流程治理等特性,適用于微服務配置管理場景。

服務端基于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 安裝包下載

1.源碼下載 從(Apollo-github[1]) 下載最新的源碼,也可以通過 git 命令下載到本地

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

2.下載安裝包 地址: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 服務端配置調整(可選項)

1. ApolloPortalDB庫配置

操作表:ServerConfig

2. ApolloConfigDB庫配置

操作表:ServerConfig

2.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. <dependency> 
  2.       <groupId>com.ctrip.framework.apollo</groupId> 
  3.       <artifactId>apollo-client</artifactId> 
  4.       <version>1.7.0</version> 
  5.   </dependency> 
  6.       數據庫jar--> 
  7.   <dependency> 
  8.       <groupId>mysql</groupId> 
  9.       <artifactId>mysql-connector-java</artifactId> 
  10.       <scope>runtime</scope> 
  11.   </dependency> 
  12.   <dependency> 
  13.       <groupId>org.springframework.boot</groupId> 
  14.       <artifactId>spring-boot-starter-data-jpa</artifactId> 
  15.       <version>1.5.9.RELEASE</version> 
  16.   </dependency> 

3.2 發布配置

創建應用

1.AppId:001

2.AppId:mxn-front-gateway

AppId是應用的身份信息,是從服務端獲取配置的一個重要信息。

AppId:001的配置內容

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

上面的兩張圖,就是我們Apollo配置中心的詳細配置頁面

  • 在頁面左上方的環境列表模塊展示了所有的環境和集群,用戶可以自由切換。
  • 頁面中央展示了兩個namespace 的配置信息,默認按照表格模式展示、編輯。用戶也可以切換到文本模式,以文件形式查看、編輯。
  • 頁面上可以方便地進行發布、回滾、灰度、授權、查看更改歷史和發布歷史等操作

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.  * @program: apollo-mxn 
  7.  * @ClassName TestController 
  8.  * @description: 
  9.  * @author: lyy 
  10.  * @create: 2021-09-15 17:45 
  11.  * @Version 1.0 
  12.  **/ 
  13. @RestController 
  14. public class TestController { 
  15.  
  16.     @Value(value = "${mxn.name}"
  17.     private String name
  18.  
  19.     @RequestMapping("test"
  20.     public String test(){ 
  21.         return "hello world "+name
  22.     } 
  23.  

這樣我們就可以 從 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.  * @program: apollo-mxn 
  17.  * @ClassName DataSourceConfig 
  18.  * @description: 實現配置信息熱加載 
  19.  * @author: lyy 
  20.  * @create: 2021-09-15 16:41 
  21.  * @Version 1.0 
  22.  **/ 
  23. @Configuration 
  24. @EnableConfigurationProperties(DataSourceProperties.class) 
  25. @Slf4j 
  26. public class ConfigHotLoad { 
  27.  
  28.     @RefreshScope 
  29.     @Bean("dataSource_Bean"
  30.     public DataSource dataSource(DataSourceProperties dataSourceProperties){ 
  31.         return dataSourceProperties.initializeDataSourceBuilder().build(); 
  32.     } 
  33.  
  34.     @Autowired 
  35.     private ApplicationContext applicationContext; 
  36.  
  37.     @Autowired 
  38.     private org.springframework.cloud.context.scope.refresh.RefreshScope refreshScope; 
  39.  
  40.     /** @Author lyy 
  41.       * @Description //TODO 監聽apollo 的配置變更 
  42.       * @Date 16:50 2021/9/15 
  43.       * @Param  
  44.       * @return  
  45.      **/ 
  46.     @ApolloConfigChangeListener(value = {ConfigConsts.NAMESPACE_APPLICATION,"dev"},interestedKeyPrefixes = {"spring.datasource"}) 
  47.     public void onChange(ConfigChangeEvent configChangeEvent){ 
  48.         // 重新編譯DataSource 初始化bean 
  49.         refreshScope.refresh("dataSource_Bean"); 
  50.         log.info("Apollo config changed {}",applicationContext.getBean(DataSourceProperties.class).toString()); 
  51.  
  52.     } 
  53.  

我們 輸入地址 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格式的配置:

1.application (應用)

2.environment (環境)

3.cluster (集群)

4.namespace (命名空間)

同時,Apollo基于開源模式開發,開源地址:https://github.com/ctripcorp/apollo

6.3 基礎模型

Apollo的基礎模型:

1.用戶在配置中心對配置進行修改并發布

2.配置中心通知Apollo客戶端有配置更新

3.Apollo客戶端從配置中心拉取最新的配置、更新本地配置并通知到應用

七、Apollo特性

由于配置的特殊性,所以Apollo 從開始設計到完善就立志作為一個有治理能力的配置中心平臺,Apollo的特性主要體現在以下幾個方面

  • 統一配置的配置管理

1.Apollo提供了一個統一界面集中式管理不同環境(environment)、不同集群(cluster)、不同命名空間(namespace)的配置。

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

3.通過命名空間(namespace)可以很方便地支持多個不同應用共享同一份配置,同時還允許應用對共享的配置進行覆蓋

  • 配置修改實時生效(熱發布)

1.用戶在Apollo修改完配置并發布后,客戶端能實時(1秒)接收到最新的配置,并通知到應用程序

  • 版本發布管理

1.所有的配置發布都有版本概念,從而可以方便地支持配置的回滾

  • 灰度發布

1.支持配置的灰度發布,比如點了發布后,只對部分應用實例生效,等觀察一段時間沒問題后再推給所有應用實例

  • 權限管理、發布審核、操作審計

1.應用和配置的管理都有完善的權限管理機制,對配置的管理還分為了編輯和發布兩個環節,從而減少人為的錯誤。

2.所有的操作都有審計日志,可以方便地追蹤問題

  • 客戶端配置信息監控

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

  • 提供Java和.Net原生客戶端

1.提供了Java和.Net的原生客戶端,方便應用集成

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

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

  • 提供開放平臺API

1.Apollo自身提供了比較完善的統一配置管理界面,支持多環境、多數據中心配置管理、權限、流程治理等特性。不過Apollo出于通用性考慮,不會對配置的修改做過多限制,只要符合基本的格式就能保存,不會針對不同的配置值進行針對性的校驗,如數據庫用戶名、密碼,Redis服務地址等

2.對于這類應用配置,Apollo支持應用方通過開放平臺API在Apollo進行配置的修改 和發布,并且具備完善的授權和權限控制

  • 部署簡單

1.配置中心作為基礎服務,可用性要求非常高,這就要求Apollo對外部依賴盡可能地少

2.目前唯一的外部依賴是MySQL,所以部署非常簡單,只要安裝好Java和MySQL就可以讓Apollo跑起來

3.Apollo還提供了打包腳本,一鍵就可以生成所有需要的安裝包,并且支持自定義運行時參數

八、Apollo原理

上圖簡要描述了Apollo客戶端的實現原理:

1.客戶端和服務端保持了一個長連接,從而能第一時間獲得配置更新的推送。

2.客戶端還會定時從Apollo配置中心服務端拉取應用的最新配置。

  • 這是一個fallback機制,為了防止推送機制失效導致配置不更新
  • 客戶端定時拉取會上報本地版本,所以一般情況下,對于定時拉取的操作,服務端都會返回304 - Not Modified
  • 定時頻率默認為每5分鐘拉取一次,客戶端也可以通過在運行時指定System >Property: apollo.refreshInterval來覆蓋,單位為分鐘。

3.客戶端從Apollo配置中心服務端獲取到應用的最新配置后,會保存在內存中

4.客戶端會把從服務端獲取到的配置在本地文件系統緩存一份

  • 在遇到服務不可用,或網絡不通的時候,依然能從本地恢復配置

5.應用程序從Apollo客戶端獲取最新的配置、訂閱配置更新通知

九、自定義Cluster

9.1 新建Cluster

點擊后就進入到集群添加頁面,一般情況下可以按照數據中心來劃分集群 不過也支持自定義集群,比如可以為A機房的某一臺機器和B機房的某一臺機創建一個集群,使用一套配置。

Apollo會默認使用應用實例所在的數據中心作為cluster,所以如果兩者一致的話,不需要額外配置。

如果cluster和數據中心不一致的話,那么就需要通過System Property方式來指定運行時cluster:

  • -Dapollo.cluster=SomeCluster
  • 這里注意apollo.cluster為全小寫

十、配置獲取規則

在有了cluster概念后,配置的規則就顯得重要了。比如應用部署在A機房,但是并沒有在Apollo新建cluster,這個時候Apollo的行為是怎樣的?或者在運行時指定了cluster=SomeCluster,但是并沒有在Apollo新建cluster,這個時候Apollo的行為是怎樣的?

10.1 應用自身配置的獲取規則

當應用使用下面的語句獲取配置時,我們稱之為獲取應用自身的配置,也就是應用自身的application namespace的配置。

Config config = ConfigService.getAppConfig();

對這種情況的配置獲取規則,簡而言之如下:

1.首先查找運行時cluster的配置(通過apollo.cluster指定)

2.如果沒有找到,則查找數據中心cluster的配置

3.如果還是沒有找到,則返回默認cluster的配置

圖示如下:

所以如果應用部署在A數據中心,但是用戶沒有在Apollo創建cluster,那么獲取的配置就是默認cluster(default)的。

如果應用部署在A數據中心,同時在運行時指定了SomeCluster,但是沒有在Apollo創建cluster,那么獲取的配置就是A數據中心cluster的配置,如果A數據中心cluster沒有配置的話,那么獲取的配置就是默認cluster(default)的。

十一、總體設計

上圖簡要描述了Apollo的總體設計,我們可以從下往上看:

  • Config Service提供配置的讀取、推送等功能,服務對象是Apollo客戶端
  • Admin Service提供配置的修改、發布等功能,服務對象是Apollo Portal(管理界面)
  • Config Service和Admin Service都是多實例、無狀態部署,所以需要將自己注冊到Eureka中并保持心跳
  • 在Eureka之上我們架了一層Meta Server用于封裝Eureka的服務發現接口
  • Client通過域名訪問Meta Server獲取Config Service服務列表(IP+Port),而后直接通過IP+Port訪問服務,同時在Client側會做load balance、錯誤重試
  • Portal通過域名訪問Meta Server獲取Admin Service服務列表(IP+Port),而后直接通過IP+Port訪問服務,同時在Portal側會做load balance、錯誤重試
  • 為了簡化部署,我們實際上會把Config Service、Eureka和Meta Server三個邏輯角色部署在同一個JVM進程中

十二、總結

到這里Apollo,就講解完了,其實Apollo 可以理解成一個好用的配置管理中心,這里小農也是了解了一點皮毛,大家有不懂的地方,歡迎留言。

我是牧小農,怕什么真理無窮,進一步有進一步的歡喜,大家加油~

 

責任編輯:姜華 來源: 牧小農
相關推薦

2021-10-14 09:58:24

消息中間件ActiveMQ Java

2022-07-06 07:57:37

Zookeeper分布式服務框架

2021-05-11 09:31:31

kustomizeoperator kubernetes

2021-05-08 09:02:48

KubeBuilderOperatork8s

2021-10-14 11:31:28

數組面試題中心下標

2021-07-12 06:11:14

SkyWalking 儀表板UI篇

2021-06-21 14:36:46

Vite 前端工程化工具

2021-01-28 08:55:48

Elasticsear數據庫數據存儲

2023-03-29 07:45:58

VS編輯區編程工具

2021-04-14 14:16:58

HttpHttp協議網絡協議

2021-04-08 11:00:56

CountDownLaJava進階開發

2021-07-21 09:48:20

etcd-wal模塊解析數據庫

2024-06-13 08:34:48

2022-03-22 09:09:17

HookReact前端

2022-02-17 08:53:38

ElasticSea集群部署

2022-04-29 14:38:49

class文件結構分析

2021-04-01 10:51:55

MySQL鎖機制數據庫

2021-03-12 09:21:31

MySQL數據庫邏輯架構

2021-10-28 08:51:53

GPIO軟件框架 Linux

2022-02-25 15:50:05

OpenHarmonToggle組件鴻蒙
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 99久久久久 | 毛片免费看| 国产一区二区三区在线看 | 91国内精品久久 | 99re6在线视频| 人人人人爽| 国产精品99视频 | 国产一区二区在线播放视频 | 欧美日韩在线播放 | 成人午夜精品一区二区三区 | 亚洲第一女人av | 成人无遮挡毛片免费看 | 日本免费黄色一级片 | 欧美成人免费在线视频 | 成人久久久久 | 粉嫩一区二区三区性色av | 精品在线观看一区二区 | 精品日韩一区 | 国产69精品久久99不卡免费版 | 毛片一级片 | 黄a免费网络 | 成人午夜精品 | 亚洲精品一区二区在线观看 | h视频在线观看免费 | 色又黄又爽网站www久久 | 久久精品视频在线免费观看 | 国产精品18久久久久久白浆动漫 | 国产精品久久久久久久久久三级 | 中文字幕 在线观看 | 操操日| 操操日 | 97国产一区二区 | 亚洲 欧美 日韩 在线 | 男人天堂网址 | 国产目拍亚洲精品99久久精品 | 国产一区二区免费在线 | 奇米久久久 | 久久i| 女同久久 | 亚洲品质自拍视频 | 中文字幕成人在线 |