基于Docker部署Dubbo+Nacos服务

打印 上一主题 下一主题

主题 550|帖子 550|积分 1650


一、说明

本文介绍基于 Docker 部署一套 Dubbo + Nacos 的微服务环境,并解决容器里的 IP 及端口的访问问题。

 
二、部署 Nacos 注册中心

拉取 nacos 注册中心镜像:
  1. docker pull nacos/nacos-server:v2.2.0
复制代码
启动 nacos:
  1. docker run --name nacos-quick \
  2.   -e MODE=standalone \
  3.   -p 8848:8848 \
  4.   -p 9848:9848 \
  5.   -p 9849:9849 \
  6.   -d nacos/nacos-server:v2.2.0
复制代码


  • 通过指定 -e MODE 来设置单机模式启动,默认是cluster
  • 通过 -p 参数来映射容器中的端口到宿主机中
 
三、部署 Dubbo 服务

由于服务的镜像在阿里云镜像服务中,所以需要先登录阿里云的 Docker Registry:
docker login --username=[用户名] [仓库地址]
仓库地址请登录自己的阿里云镜像服务中查看:https://cr.console.aliyun.com/
例如执行以下命令,并按提示输入正确的密码:
  1. docker login --username=zltdiablo@163.com registry.cn-guangzhou.aliyuncs.com
复制代码
用户名为阿里云账号全名,密码为开通镜像仓库服务时设置的密码。
 
3.1. 部署 provider 服务

拉取阿里云镜像的命令格式为:
docker pull [仓库地址]/[命名空间]/[仓库名]:[镜像版本号]
拉取 provider 服务镜像:
  1. docker pull registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-provider:1.0-SNAPSHOT
复制代码
启动 provider 服务:
  1. docker run -d \
  2.   --name dubbo-nacos-provider \
  3.   -e DUBBO_IP_TO_REGISTRY="192.168.28.130" \
  4.   -p 20880:20880 \
  5.   registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-provider:1.0-SNAPSHOT
复制代码


  • 通过 DUBBO_IP_TO_REGISTRY 参数设服务注册的 ip 为宿主机的地址
  • 使用 -p 暴露 dubbo 的端口
 
3.2. 部署 consumer 服务

拉取 consumer 服务镜像:
  1. docker pull registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-consumer:1.0-SNAPSHOT
复制代码
启动 consumer 服务:
  1. docker run -d \
  2.   --name dubbo-nacos-consumer \
  3.   -p 8080:8080 \
  4.   registry.cn-guangzhou.aliyuncs.com/zlt-test/nacos-consumer:1.0-SNAPSHOT
复制代码
服务启动成功后,可在浏览器中输入以下地址进行测试:
  1. http://宿主机ip:8080/test?name=zlt
复制代码
访问 dubbo-nacos-consumer 服务中的 controller 接口,调用 dubbo-nacos-provider 服务中的 dubbo 接口,返回结果。
 
四、样例工程

集成 jib-maven-plugin 插件的样例 Spring Boot 工程:
 
扫码关注有惊喜!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

滴水恩情

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表