微服务框架(七)Docker容器部署(Dubbo、Zookeeper、Dubbo-admin)

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 此系列文章将会描述Java框架**Spring Boot**、服务治理框架**Dubbo**、应用容器引擎**Docker**,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现,然后通过gitlab-CI以持续集成为Docker镜像。  **本文为Docker容器部署,包括Dubbo微服务、Zookeeper、Dubbo-admin的部署**

  此系列文章将会描述Java框架Spring Boot、服务治理框架Dubbo、应用容器引擎Docker,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现,然后通过gitlab-CI以持续集成为Docker镜像。
  本文为Docker容器部署,包括Dubbo微服务、Zookeeper、Dubbo-admin的部署

本系列文章中所使用的框架版本为Spring Boot 2.0.3-RELEASE,Spring 5.0.7-RELEASE,Dubbo 2.6.2。

Docker容器启动参数

运行参数说明:

  • -d: 后台运行容器,并返回容器ID
  • -i: 以交互模式运行容器,通常与-t同时使用
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用
  • --name: 为容器指定一个名称
  • -e: 设置环境变量
  • --env-file: 从指定文件读取环境变量
  • -p: 端口映射,如果不做端口映射,容器外部无法访问容器内部
  • -v: 文件挂载
  • --link: 添加链接到容器,在default网络下,默认不会将容器名称解析到容器IP地址,必须要添加link选项才可以。而在自定义网络下,则不需要添加此选项

更多选项可以查看docker文档

Docker容器部署

网络接口及数据卷

 # 创建网络接口
sudo docker network create zookeeper
sudo docker network create dubbo

 # volumn创建,用来持久化数据
sudo docker volume create background
sudo docker volume create dubbo

Zookeeper

 # zookeeper注册中心
sudo docker run -d \
    --name zookeeper \
    --net zookeeper \
    --net dubbo \
    -v background:/var/lib/zookeeper/data \
    -p 2181:2181 \
    -p 2888:2888 \
    -p 3888:3888 \
    --restart=always \
    jplock/zookeeper:3.4.11

dubbo-admin

 # dubbo-admin管理中心
docker run -d \
    --name dubbo-admin \
    --net zookeeper \
    -v background:/data \
    -p 9600:8080 \
    -e DUBBO_REGISTRY="zookeeper:\/\/ip:port" \
    -e DUBBO_ROOT_PASSWORD=root \
    -e DUBBO_GUEST_PASSWORD=guest \
    --restart=always \
    riveryang/dubbo-admin

dubbo-monitor

 # dubbo-monitor监控中心
docker run -d \
    --name dubbo-monitor \
    --net zookeeper \
    -v background:/dubbo-monitor/data \
    -e DUBBO_IP_TO_REGISTRY=ip \
    -e DUBBO_PORT_TO_REGISTRY=9700 \
    -p <ip>:9700:9700 \
    -p 9601:9601 \
    --restart=always \
    jeromefromcn/dubbo-monitor

Dubbo微服务

 # Dubbo微服务
docker run -d \
    --name <containerName> \
    --net dubbo \
    -e DUBBO_IP_TO_REGISTRY=<ip> \
    -e DUBBO_PORT_TO_REGISTRY=<port> \
    -p <ip>:<port>:<port> \
    -v dubbo:/log \
    --restart=always \
    <imageName> \
    --spring.profiles.active=<env>

Docker常用命令

这里写图片描述

命令里使用${CONTAINER_ID}${CONTAINER_NAME}均可

查看容器状态

docker ps | grep ${CONTAINER_ID}

查看容器日志

docker logs ${CONTAINER_ID}

交互式进入容器中

docker exec -i -t ${CONTAINER_ID} sh

查看容器底层信息

docker inspect ${CONTAINER_ID}

镜像打包

docker commit -m "message" -a  "author" ${CONTAINER_ID}  ${NEW_IMAGE_NAME}

标签

docker tag ${IMAGE_TAG}  ${NEW_IMAGE_TAG}

推送至对应仓库

docker push ${REGISTRY_URL}/${IMAGE_NAME}

删除所有退出的容器

docker rm $(docker ps -a | grep Exit | awk '{ print $1 }')

删除所有名称为none的镜像

docker images | grep none | awk '{print $3} ' | xargs docker rmi

参考资料:

  1. 《容器与容器云》
相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
1月前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
2月前
|
运维 Kubernetes Cloud Native
云原生技术:容器化与微服务架构的完美结合
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术以其灵活性和高效性成为企业的新宠。本文将深入探讨云原生的核心概念,包括容器化技术和微服务架构,以及它们如何共同推动现代应用的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务,揭示云原生技术的强大能力和未来潜力。
|
16天前
|
SpringCloudAlibaba JavaScript Dubbo
【SpringCloud Alibaba系列】Dubbo dubbo-admin安装教程篇
本文介绍了 Dubbo-Admin 的安装和使用步骤。Dubbo-Admin 是一个前后端分离的项目,前端基于 Vue,后端基于 Spring Boot。安装前需确保开发环境(Windows 10)已安装 JDK、Maven 和 Node.js,并在 Linux CentOS 7 上部署 Zookeeper 作为注册中心。
【SpringCloud Alibaba系列】Dubbo dubbo-admin安装教程篇
|
27天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
98 24
|
24天前
|
消息中间件 人工智能 Kubernetes
解密开源Serverless容器框架:事件驱动篇
Knative是一款基于Kubernetes的开源Serverless框架,提供了云原生、跨平台的Serverless编排标准。作为Serverless中必不可少的事件驱动能力,Knative Eventing提供了云原生的事件驱动能力。
|
29天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
131 6
|
1月前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器化到微服务
本文将带领读者踏上云原生的旅程,深入探讨容器化和微服务架构的概念、优势以及它们如何共同推动现代软件的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务应用,并解释相关的配置和操作。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供有价值的见解和实操指南。
|
2月前
|
Kubernetes Cloud Native 开发者
云原生入门:从容器到微服务
本文将带你走进云原生的世界,从容器技术开始,逐步深入到微服务架构。我们将通过实际代码示例,展示如何利用云原生技术构建和部署应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和启示。
|
2月前
|
Kubernetes Cloud Native 持续交付
容器化、Kubernetes与微服务架构的融合
容器化、Kubernetes与微服务架构的融合
51 1
|
2月前
|
运维 Kubernetes Docker
深入理解容器化技术及其在微服务架构中的应用
深入理解容器化技术及其在微服务架构中的应用
70 1
下一篇
开通oss服务