一、說明
本文介紹基於 Docker
部署一套 Dubbo
+ Nacos
的微服務環境,並解決容器裡的 IP 及埠的訪問問題。
- 基於上文《基於jib-maven-plugin快速構建微服務docker映象》 中在阿里雲映象倉庫構建的映象來進行部署。
二、部署 Nacos 註冊中心
拉取 nacos 註冊中心映象:
docker pull nacos/nacos-server:v2.2.0
啟動 nacos:
docker run --name nacos-quick \
-e MODE=standalone \
-p 8848:8848 \
-p 9848:9848 \
-p 9849:9849 \
-d nacos/nacos-server:v2.2.0
- 透過指定 -e MODE 來設定單機模式啟動,預設是cluster
- 透過 -p 引數來對映容器中的埠到宿主機中
三、部署 Dubbo 服務
由於服務的映象在阿里雲映象服務中,所以需要先登入阿里雲的 Docker Registry:
docker login --username=[使用者名稱] [倉庫地址]
倉庫地址請登入自己的阿里雲映象服務中檢視:https://cr.console.aliyun.com/
例如執行以下命令,並按提示輸入正確的密碼:
docker login --username=zltdiablo@163.com registry.cn-guangzhou.aliyuncs.com
使用者名稱為阿里雲賬號全名,密碼為開通映象倉庫服務時設定的密碼。
3.1. 部署 provider 服務
拉取阿里雲映象的命令格式為:
docker pull [倉庫地址]/[名稱空間]/[倉庫名]:[映象版本號]
拉取 provider 服務映象:
docker pull registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-provider:1.0-SNAPSHOT
啟動 provider 服務:
docker run -d \
--name dubbo-nacos-provider \
-e DUBBO_IP_TO_REGISTRY="192.168.28.130" \
-p 20880:20880 \
registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-provider:1.0-SNAPSHOT
- 透過 DUBBO_IP_TO_REGISTRY 引數設服務註冊的 ip 為宿主機的地址
- 使用 -p 暴露 dubbo 的埠
3.2. 部署 consumer 服務
拉取 consumer 服務映象:
docker pull registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-consumer:1.0-SNAPSHOT
啟動 consumer 服務:
docker run -d \
--name dubbo-nacos-consumer \
-p 8080:8080 \
registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-consumer:1.0-SNAPSHOT
服務啟動成功後,可在瀏覽器中輸入以下地址進行測試:
http://宿主機ip:8080/test?name=zlt
訪問 dubbo-nacos-consumer 服務中的 controller 介面,呼叫 dubbo-nacos-provider 服務中的 dubbo 介面,返回結果。
四、樣例工程
整合 jib-maven-plugin
外掛的樣例 Spring Boot
工程:
- https://gitee.com/zlt2000_admin/zlt-dubbo-samples/tree/master/dubbo-nacos
- https://github.com/zlt2000/zlt-dubbo-samples/tree/master/dubbo-nacos
掃碼關注有驚喜!