乐趣区

关于云计算:基于Docker部署DubboNacos服务

一、阐明

本文介绍基于 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_adm…
  • https://github.com/zlt2000/zl…

 

扫码关注有惊喜!

退出移动版