Apollo(阿波羅)是攜程框架部門研發(fā)的分布式配置中心,能夠集中化管理應(yīng)用不同環(huán)境、不同集群的配置,配置修改后能夠?qū)崟r推送到應(yīng)用端,并且具備規(guī)范的權(quán)限、流程治理等特性,適用于微服務(wù)配置管理場景。
Apollo 與 properties 配置文件的功能相同,都可以設(shè)置參數(shù)。Apollo 的優(yōu)點(diǎn)在于,可以實時修改參數(shù)的值,而不需要重啟項目。
1 環(huán)境準(zhǔn)備
需要 Java 1.8 及以上,MySQL 5.6 及以上的版本。
MySQL安裝配置方式:https://mp.weixin.qq.com/s/ISCjsIpmccVnuvXPkiFLMw
如果只是本地測試的話,推薦使用 GitHub 上的開源項目 Apollo Quick Start;
安裝包下載地址:https://pan.baidu.com/s/11dYV5x1Qu7svEGaJLShoqQ?pwd=6666
提取碼:6666
2 SQL 導(dǎo)入
下載并解壓安裝包 apollo-quick-start-2.0.1.zip,可以看到目錄下有 sql 文件夾,里面有 apolloconfigdb.sql 和 apolloportaldb.sql 兩個文件,需要將這兩個文件導(dǎo)入 MySQL中。
打開 win 菜單中的 MySQL 8.0 Command Line Client - Unicode 命令,
運(yùn)行:
source D:\\\\\\\\\\\\\\\\Apollo\\\\\\\\\\\\\\\\apollo-quick-start-2.0.1\\\\\\\\\\\\\\\\sql\\\\\\\\\\\\\\\\apolloconfigdb.sql
source D:\\\\\\\\\\\\\\\\Apollo\\\\\\\\\\\\\\\\apollo-quick-start-2.0.1\\\\\\\\\\\\\\\\sql\\\\\\\\\\\\\\\\apolloportaldb.sql
D:\\\\\\\\\\\\\\\\Apollo
是我存放 apollo-quick-start-2.0.1 文件夾的路徑。
即可完成導(dǎo)入。
導(dǎo)入成功后,可以通過執(zhí)行以下sql語句來驗證:
select `NamespaceId`, `Key`, `Value`, `Comment` from ApolloConfigDB.Item;
有以下輸出,表示導(dǎo)入成功。
3 啟動 Apollo
編輯 apollo-quick-start-2.0.1文件夾下的 demo.sh,修改 ApolloPortalDB 和 ApolloConfigDB 相關(guān)的數(shù)據(jù)庫連接配置信息。
#apollo config db info
apollo_config_db_url=jdbc:mysql://localhost:3306/ApolloConfigDB?characterEncoding=utf8
apollo_config_db_username=root
apollo_config_db_password=root
# apollo portal db info
apollo_portal_db_url=jdbc:mysql://localhost:3306/ApolloPortalDB?characterEncoding=utf8
apollo_portal_db_username=root
apollo_portal_db_password=root
我的數(shù)據(jù)庫的賬號密碼均為 root。
找到 demo.sh 的第72行,將 cd "${0%/*}"
改為當(dāng)前路徑:
cd D:\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\Apollo\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\apollo-quick-start-2.0.1\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\
打開 win 菜單中的 Git Bash,運(yùn)行 demo.sh 。
D:\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\Apollo\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\apollo-quick-start-2.0.1\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\demo.sh start
等待運(yùn)行一段時間后,當(dāng)看到如下輸出,就說明啟動成功了。
==== starting service ====
Service logging file is ./service/apollo-service.log
Started [10768]
Waiting for config service startup.......
Config service started. You may visit http://localhost:8080 for service status now!
Waiting for admin service startup....
Admin service started
==== starting portal ====
Portal logging file is ./portal/apollo-portal.log
Started [10846]
Waiting for portal startup......
Portal started. You can visit http://localhost:8070 now!
訪問 http://localhost:8070 ,輸入用戶名 apollo,密碼 admin,即可登錄。
停止運(yùn)行命令:
D:\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\Apollo\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\apollo-quick-start-2.0.1\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\demo.sh stop
需要注意,apollo 端口號為8070,但在 Java 工程的 properties 中, apollo.meta
設(shè)置的端口號應(yīng)為 Eureka 的端口號8080。
4 使用 Apollo
點(diǎn)擊創(chuàng)建應(yīng)用:
輸入自定義的參數(shù):
即可創(chuàng)建成功。然后在新創(chuàng)建的應(yīng)用中增加配置:
5 項目實例
下載一個測試項目 learn-apollo
:
GitHub地址:https://github.com/Snowstorm0/learn-apollo
Gitee地址:https://gitee.com/Snowstorm0/learn-apollo
在運(yùn)行項目之前需要修改 resource/application.properties 中 apollo.meta 的值,將 localhost 替換為 apollo 的地址,端口號為 Eureka 的端口號(默認(rèn)為8080)。
在 Apollo 中新增并發(fā)布如下三個參數(shù):
learn-apollo
是一個定時任務(wù),可以每隔5秒輸出一次apollo的參數(shù)信息。
運(yùn)行該項目,輸出:
paramStr:str1
然后在apollo中修改參數(shù)的值,將str1
改為str2
。
不需要重啟項目,此時項目會輸出參數(shù)更新的日志信息:
[Apollo-Config-1] c.f.a.s.p.AutoUpdateConfigChangeListener :
Auto update apollo changed value successfully,
new value: paramStr7, key: param.paramStr, beanName: myService,
field: com.spring.boot.service.MyService.paramStr
項目的輸出也變了:
paramStr:str2
-
JAVA
+關(guān)注
關(guān)注
19文章
2967瀏覽量
104746 -
MySQL
+關(guān)注
關(guān)注
1文章
809瀏覽量
26564 -
Apollo
+關(guān)注
關(guān)注
5文章
342瀏覽量
18450
發(fā)布評論請先 登錄
相關(guān)推薦
評論