https://blog.51cto.com/12980017/2158490?source=dra
由於Apollo支持的圖形化界面相對於我們更加的友好,所以此次我們使用Apollo來做配置中心
本篇文章實現了使用Apollo配置了dev和fat兩個環境下的屬性配置。
Apollo官方文檔https://github.com/ctripcorp/apollo/wiki
1.下載依賴
-
從https://github.com/ctripcorp/apollo/releases頁面下載最新版本的apollo-configservice-x.x.x-github.zip、apollo-adminservice-x.x.x-github.zip和apollo-portal-x.x.x-github.zip依賴包(需要×××。不能×××的同學建議使用第二種方式)。
-
從https://github.com/ctripcorp/apollo下載源碼后在本地構建。構建步驟為:
-
下載項目所需依賴
-
使用scripts文件夾下的build.bat或build.sh構建
-
分別拷貝出apollo-adminservice、apollo-configservice和apollo-portal三個文件夾下target/apollo-xxx-x.x.x-github.zip文件
2. 創建數據庫
-
從https://github.com/ctripcorp/apollo/tree/master/scripts/sql下載apolloconfigdb.sql和apolloportaldb.sql數據庫文件。
-
使用apolloportaldb.sql文件創建apolloportaldb數據庫,此數據庫是我們管理各種環境等的通用數據庫。
-
使用apolloconfigdb.sql文件分別創建apolloconfigdb_dev和apolloconfigdb_fat數據庫作為我們兩個環境的數據存儲。
3.配置數據庫連接信息
-
解壓第一步下載的三個壓縮文件
-
apollo-portal-1.0.0-github
-
在apollo-portal-1.0.0-github/config下application-github.properties文件中配置 apolloportaldb數據庫的連接信息。
-
打開apollo-env.properties文件修改dev.mate和fat.mate屬性值為不同環境對 應的Eureka地址。例如在這里我fat環境使用的本地,dev使用的是服務器地址
-
復制一份apollo-adminservice-1.0.0-github文件,分別重命名為apollo-adminservice-dev和apollo-adminservice-fat。
-
在apollo-adminservice-dev和apollo-adminservice-fat 的config文件夾下的application-github.properties文件中分別配置 apolloconfigdb_dev和apolloconfigdb_fat數據庫的連接信息。
-
按照3.4步驟復制apollo-configservice-1.0.0-github並分別配置數據連接地址
現在的數據庫連接信息如下所示:
4.啟動服務
-
使用apollo時portal只需要啟動一個來進行管理,在這里我們暫時把它放在本地啟動。為了啟動方面,使用一個小的腳本
1 |
|
-
將apollo-configservice-dev和apollo-adminservice-dev上傳到服務器,使用如下命令啟動
1 |
sh ./apollo-configservice-dev/scripts/startup.sh |
-
現在我們訪問http://localhost:8080/以及http://10.10.10.10:8080/可以看到以下信息就沒問題了
-
修改數據庫apolloconfigdb_dev和apolloconfigdb_fat中的ServerConfig表中的key為eureka.service.url的數據,將value分別置為http://10.10.10.10:8080/eureka/和http://localhost:8080/eureka/
5.測試
-
創建一個maven工程,引入apollo的相關依賴
1 |
<apollo.version>1.0.0</apollo.version> |
-
在application.yml中指定應用的id,以及apollo配置中心的地址
1 |
App: |
-
創建ConfigRefresher類
1 |
|
-
創建啟動類並啟動
1 |
@SpringBootApplication |
-
修改配置文件中的 apollo.Meta為localhost:8080再次啟動
-
打開瀏覽器訪問 http://localhost:8070 Apollo默認的用戶名為 apollo,密碼為admin。登陸后點擊創建項目,項目的應用id和名稱填寫我們配置文件中的app.id。
-
進入項目可在dev和fat環境中分別發布不同的配置進行測試
===================
由於現在服務器啟動的時候會有很多配置文件需要加載,而且有多套環境時,會有部分配置不同,所以管理起來不太方便,就可以使用攜程的apollo來進行統一管理
由於apollo是新出來的配置中心,更新很快,年初使用的0.幾的版本還需要自己打包,
現在1.0版本出來之后,不需要自己打包了,只需要下載官方的壓縮包,然后自己修改配置就能使用
下面就記錄一下我操作的過程,避免一段時間后又忘記了
創建數據庫
SQL腳本:https://github.com/ctripcorp/apollo/tree/master/scripts/sql
由於需要管理多套環境,所以需要修改下數據庫名稱,創建多個數據庫
由於我是管理兩套環境,所以創建兩個config庫,一個portal庫(Portal始終只需要一個就行)
去數據庫執行腳本,以下是我的數據庫執行后的效果
還需要手動修改一下數據庫的部分配置
1.ApolloPortalDB.ServerConfig
2.ApolloConfigDB.ServerConfig(不同的環境都需要修改自己數據庫的該字段,端口和啟動腳本設置端口一致)
獲取安裝包
安裝包地址:https://github.com/ctripcorp/apollo/releases
修改配置
1.portal
scripts\startup.sh 修改端口號(默認是端口容易沖突,所以自己修改未使用的端口號,也便於管理),日志目錄也可以根據自己習慣改動
config/apollo-env.properties 配置需要管理的環境的config端口
config/application-github.properties 配置portal的數據庫連接
2.config
scripts\startup.sh 修改端口號(原理與Portal修改一樣,防止沖突,便於管理),日志目錄也可以根據自己習慣改動
config/application-github.properties 配置apollo-config的數據庫連接(此處是連接的dev環境的配置,因為我有多套環境的配置,若是pro環境的配置,則連pro的數據庫就好)
3.admin
scripts\startup.sh 修改端口號(原理與Portal修改一樣,防止沖突,便於管理),日志目錄也可以根據自己習慣改動
config/application-github.properties 配置apollo-config的數據庫連接(此處是連接的dev環境的配置,因為我有多套環境的配置)
服務部署
將自己修改好配置的安裝包上傳到服務器(我是放在/opt/apollo文件夾下,位置自己定,關系不大)
然后修改script文件夾的權限,因為默認是讀寫權限,沒有執行權限 :chmod -R 755 scripts,這樣啟動和停止腳本就有了執行權限,每個script文件夾都需要執行權限
然后再執行每個startup.sh文件(可能會失敗,失敗就需要看啟動日志了,日志路徑啟動腳本里面有配置),全部啟動成功之后,就可以去頁面訪問我們的apollo的portal了
賬號密碼默認為 apollo / admin
進來后就能看到自己配置的多套環境了
---------------------
作者:gaojie_csdn
來源:CSDN
原文:https://blog.csdn.net/gaojie_csdn/article/details/83510839
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!