本文介绍基于 Docker
部署一套 Dubbo
+ Nacos
的微服务环境,并解决容器里的 IP 及端口的访问问题。
基于上文《基于jib-maven-plugin快速构建微服务docker镜像》 中在阿里云镜像仓库构建的镜像来进行部署。
拉取 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
由于服务的镜像在阿里云镜像服务中,所以需要先登录阿里云的 Docker Registry:docker login --username=[用户名] [仓库地址]
仓库地址请登录自己的阿里云镜像服务中查看:https://cr.console.aliyun.com/
例如执行以下命令,并按提示输入正确的密码:
docker login --username=zltdiablo@163.com registry.cn-guangzhou.aliyuncs.com
用户名为阿里云账号全名,密码为开通镜像仓库服务时设置的密码。
拉取阿里云镜像的命令格式为: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
拉取 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