基於Docker部署Dubbo+Nacos服務

file

一、說明

本文介紹基於 Docker 部署一套 Dubbo + Nacos 的微服務環境,並解決容器裏的 IP 及端口的訪問問題。

 

二、部署 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 [email protected] 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 工程:

 

掃碼關注有驚喜!

file

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章