目錄
- 一、說明
- 二、部署 Nacos 注冊中心
- 三、部署 Dubbo 服務(wù)
- 3.1. 部署 provider 服務(wù)
- 3.2. 部署 consumer 服務(wù)
- 四、樣例工程

一、說明
本文介紹基于 Docker 部署一套 Dubbo + Nacos 的微服務(wù)環(huán)境,并解決容器里的 IP 及端口的訪問問題。
基于上文《基于jib-maven-plugin快速構(gòu)建微服務(wù)docker鏡像》 中在阿里云鏡像倉庫構(gòu)建的鏡像來進行部署。
二、部署 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 來設(shè)置單機模式啟動,默認是cluster
- 通過 -p 參數(shù)來映射容器中的端口到宿主機中
三、部署 Dubbo 服務(wù)
由于服務(wù)的鏡像在阿里云鏡像服務(wù)中,所以需要先登錄阿里云的 Docker Registry:docker login --username=[用戶名] [倉庫地址]
倉庫地址請登錄自己的阿里云鏡像服務(wù)中查看:https://cr.console.aliyun.com/
例如執(zhí)行以下命令,并按提示輸入正確的密碼:
docker login [email protected] registry.cn-guangzhou.aliyuncs.com
用戶名為阿里云賬號全名,密碼為開通鏡像倉庫服務(wù)時設(shè)置的密碼。
3.1. 部署 provider 服務(wù)
拉取阿里云鏡像的命令格式為:docker pull [倉庫地址]/[命名空間]/[倉庫名]:[鏡像版本號]
拉取 provider 服務(wù)鏡像:
docker pull registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-provider:1.0-SNAPSHOT
啟動 provider 服務(wù):
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 參數(shù)設(shè)服務(wù)注冊的 ip 為宿主機的地址
- 使用 -p 暴露 dubbo 的端口
3.2. 部署 consumer 服務(wù)
拉取 consumer 服務(wù)鏡像:
docker pull registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-consumer:1.0-SNAPSHOT
啟動 consumer 服務(wù):
docker run -d \ --name dubbo-nacos-consumer \ -p 8080:8080 \ registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-consumer:1.0-SNAPSHOT
服務(wù)啟動成功后,可在瀏覽器中輸入以下地址進行測試:
http://宿主機ip:8080/test?name=zlt
訪問 dubbo-nacos-consumer 服務(wù)中的 controller 接口,調(diào)用 dubbo-nacos-provider 服務(wù)中的 dubbo 接口,返回結(jié)果。
四、樣例工程
集成 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






