Docker的运用

文章目录

    • 一、 Docker介绍
    • 二、Docker常用命令
    • 三、Docker 部署微服务项目
    • 四、Docker 使用场景
    • 五、Docker模拟场景
      • 5.1 模拟部署Nacos
      • 5.2 模拟部署Mongodb
      • 5.3 模拟部署RabbitMQ

一、 Docker介绍

Docker是一种开源软件平台,用于在不同的操作系统(如Windows、Linux等)之间隔离应用程序,以便更有效和可靠地管理这些应用程序的部署和运行。 Docker平台由三个基本概念组成:

  1. 镜像(Image):镜像是 Docker 包含应用所需的一切的文件系统和配置的静态表示。镜像是一个只读的模板,可以用来创建 Docker 容器。

  2. 容器(Container):容器是镜像的运行时实例。容器包含了一个应用程序及其依赖项,并且可以在任何 Docker 主机上运行。

  3. 仓库(Repository):仓库是存放镜像的地方,类似于代码仓库。Docker Hub是一个公共的仓库,用户可以从中获取各种镜像。

Docker平台的优势包括:

  1. 快速部署:Docker平台可以快速创建和部署应用程序,无需很长时间的安装和配置过程。

  2. 可靠性:Docker的容器隔离使应用程序更加可靠,因为它可以避免依赖项冲突和环境变化。

  3. 可移植性:由于 Docker 平台在各种操作系统上都能运行,因此应用程序可以更轻松地在不同的环境中迁移。

在应用程序开发中,Docker 可以在以下方面提供帮助:

  1. 开发环境一致性:开发人员可以使用 Docker 镜像构建开发环境,以确保团队成员之间具有一致的开发环境。

  2. 持续集成和部署:Docker 使得在 CI/CD 环境中更容易进行自动化部署和升级操作,帮助开发人员更加频繁地发布和测试新版本。

  3. 开发和生产环境一致性:使用 Docker 平台可以确保在开发和生产环境中使用完全相同的应用程序和配置,从而减少可能会导致生产环境故障的变量。

二、Docker常用命令

  • docker run:运行一个容器
  • docker ps:列出所有正在运行的容器
  • docker images:列出所有镜像
  • docker stop:停止一个或多个容器
  • docker rm:删除一个或多个容器
  • docker rmi:删除一个或多个镜像
  • docker build:构建一个新的镜像
  • docker exec:在正在运行的容器中执行命令
  • docker inspect:查看容器或镜像的详细信息
  • docker logs:查看容器的日志信息
  • docker pull:下载一个镜像
  • docker push:将本地的镜像推送到远程仓库
  • docker-compose:使用docker-compose命令编排容器
  • docker network:管理Docker网络
  • docker volume:管理Docker卷

三、Docker 部署微服务项目

Docker 部署微服务项目需要以下步骤:

  1. 准备 Docker 镜像

首先需要将微服务应用程序打包成 Docker 镜像。可以使用 Dockerfile 文件定义 Docker 镜像的构建过程,然后使用命令 docker build 构建镜像。

  1. 部署 Docker 镜像

在 Docker 主机上部署 Docker 镜像,可以使用 Docker compose 工具来定义和管理多个 Docker 容器的生命周期。在 Docker Compose 文件中,定义每个组件(或微服务)所需的镜像、环境变量、网络配置等。

  1. 配置 Docker 网络

微服务应用程序在 Docker 中运行时,需要使用 Docker 网络来实现相互通信。可以创建自定义 Docker 网络来提供服务发现和负载均衡等功能。

  1. 监控和管理

使用 Docker 容器和镜像管理工具,如 Docker Swarm,Kubernetes 等来监控、管理、升级和扩展微服务应用程序。

总体来说,Docker 可以帮助简化微服务应用程序的部署、升级和扩展过程,提高应用程序的可靠性和可维护性。

四、Docker 使用场景

  1. 快速开发环境搭建:Docker 可以快速构建适合于不同语言、不同框架的开发环境,避免本地环境的差异性。

  2. 应用的打包和发布:将应用程序和其依赖项打包到一个 Docker 镜像中,然后在各种环境中进行部署,包括本地环境、云环境或者其他服务器。

  3. 微服务架构:Docker 可以在其容器中高效地运行各种服务,包括数据库、缓存、消息队列等,让整个架构变得更加模块化和可维护。

  4. 持续集成和持续部署:Docker 可以与 CI/CD 工具一起使用,提高应用程序的交付速度和质量。

  5. 多租户环境:Docker 可以在一个主机上运行多个容器,每个容器隔离运行,可以实现多租户的环境。

五、Docker模拟场景

5.1 模拟部署Nacos

Nacos是一个开源的,易于构建,易于使用的动态服务发现,配置管理和服务管理平台。Nacos使用了一系列的技术来实现它的功能,其中包括Spring Cloud Config,Eureka,Dubbo等。

在Docker中,我们可以使用Nacos来模拟部署,下面是具体的步骤:

  1. 安装Docker和Docker Compose

在使用Docker模拟部署Nacos之前,我们需要先安装Docker和Docker Compose。

  1. 下载Nacos的Docker镜像

使用以下命令从Docker Hub下载Nacos的Docker镜像:

docker pull nacos/nacos-server
  1. 创建Docker Compose文件

创建一个docker-compose.yaml文件,将以下内容复制到文件中。

version: '3.1'
services:nacos:image: nacos/nacos-servercontainer_name: nacosports:- "8848:8848"environment:- PREFER_HOST_MODE=hostnamevolumes:- "./data:/home/nacos/data"- "./logs:/home/nacos/logs"- "./init.d:/home/nacos/init.d"

其中,我们将Nacos映射到端口号为8848,并将数据和日志保存在本地的data和logs目录中。

  1. 启动Nacos

使用以下命令启动Nacos:

docker-compose up -d
  1. 访问Nacos

访问http://localhost:8848/nacos/,即可进入Nacos的控制台。

至此,我们已经成功地使用Docker模拟部署了Nacos。可以在控制台中进行服务的注册和发现等操作。

5.2 模拟部署Mongodb

要使用 Docker 模拟部署 Mongodb,可以按照以下步骤操作:

  1. 安装 Docker:在您的计算机上安装 Docker。

  2. 下载 Mongodb 镜像:使用以下命令从 Docker Hub 下载最新的 Mongodb 镜像。

docker pull mongo
  1. 运行 Mongodb 容器:使用以下命令运行 Mongodb 容器。
docker run -d -p 27017:27017 --name mymongodb mongo

注:-d 选项用于在后台运行容器,-p 选项将容器端口映射到主机端口,–name 选项为容器命名。

  1. 测试 Mongodb 容器:使用以下命令测试 Mongodb 容器是否正在运行。
docker ps

如果一切正常,您应该能够看到正在运行的容器。

  1. 连接 Mongodb 容器:使用以下命令连接到 Mongodb 容器。
docker exec -it mymongodb bash
  1. 运行 Mongodb shell:使用以下命令运行 Mongodb shell。
mongo

现在您可以在 Mongodb shell 中使用所有 Mongodb 命令来管理数据库。

  1. 退出 Mongodb shell:使用以下命令退出 Mongodb shell。
exit
  1. 停止 Mongodb 容器:使用以下命令停止 Mongodb 容器。
docker stop mymongodb

现在,您已经成功地使用 Docker 模拟部署了 Mongodb。

5.3 模拟部署RabbitMQ

在Docker中模拟部署RabbitMQ可以分为以下步骤:

  1. 下载RabbitMQ镜像
docker pull rabbitmq:management
  1. 运行RabbitMQ容器
docker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:management
  1. 访问RabbitMQ的web管理页面
    在浏览器中输入 http://localhost:15672 访问RabbitMQ的web管理页面,默认用户名和密码为 guest/guest

  2. 配置RabbitMQ
    我们可以在web管理页面中配置RabbitMQ,例如创建队列、交换机、绑定等等。

  3. 连接RabbitMQ
    我们可以使用客户端代码连接RabbitMQ,例如使用Python的pika库连接RabbitMQ并发送和接收消息。

参考代码如下:

import pika# 连接RabbitMQ
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()# 创建队列
channel.queue_declare(queue='hello')# 发送消息
channel.basic_publish(exchange='',routing_key='hello',body='Hello World!')
print(" [x] Sent 'Hello World!'")# 定义回调函数
def callback(ch, method, properties, body):print(" [x] Received %r" % body)# 接收消息
channel.basic_consume(queue='hello',on_message_callback=callback,auto_ack=True)print(' [*] Waiting for messages. To exit press CTRL+C')
channel.start_consuming()

以上就是在Docker中模拟部署RabbitMQ的步骤。

盈若安好,便是晴天

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/58575.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RxJS如何根据事件创建Observable对象?

RxJS提供了一些用来创建Observable对象的函数,我们可以根据事件、定时器、Promise,AJAX等来创建Observable对象。 下面是根据事件创建Observable对象的几个例子。 this.outsideClick$ fromEvent(document, click).subscribe((event: MouseEvent) > …

C语言日常刷题6

文章目录 题目答案与解析1234567 题目 1、以下对C语言函数的有关描述中,正确的有【多选】( ) A: 在C语言中,一个函数一般由两个部分组成,它们是函数首部和函数体 B: 函数的实参和形参可以是相同的名字 C: 在main()中定…

三电平离网逆变器接不平衡负载仿真

文章目录 **0、系统框图****1、纯阻性负载R****2、纯感性负载L****3、纯容性负载C****4、 RL负载****5、RC负载****6、CL负载****7、RLC负载** 0、系统框图 闭环控制 PWM调制 逆变桥 LCL滤波电路 负载(可配置) 坐标变换(采样得到)…

HTTP:http上传文件的原理及java处理方法的介绍

为了说明原理&#xff0c;以下提供一个可以上传多个文件的例子&#xff0c;html页面代码如下&#xff1a; <!DOCTYPE html> <html> <head> <meta charset"UTF-8"> <title>http upload file</title> </head> <body>…

《存储IO路径》专题:IO虚拟化初探

大家好&#xff0c;欢迎来到今天的科技小课堂。今天我们要聊聊的是一项非常有趣且实用的技术——I/O虚拟化&#xff08;Input/Output Virtualization&#xff0c;简称IOV&#xff09;。想象一下&#xff0c;如果把物理硬件资源比作一道丰盛的大餐&#xff0c;那么IOV就是那位神…

【VRRP】虚拟路由冗余协议

什么是VRRP&#xff1f; 虚拟路由冗余协议VRRP&#xff08;Virtual Router Redundancy Protocol&#xff09;是一种用于提高网络可靠性的容错协议。通过VRRP&#xff0c;可以在主机的下一跳设备出现故障时&#xff0c;及时将业务切换到备份设备&#xff0c;从而保障网络通信的…

SQL注入之联合查询

文章目录 联合查询是什么&#xff1f;联合查询获取cms账号密码尝试登录 联合查询是什么&#xff1f; 适用数据库中的内容会回显到页面中来的情况。联合查询就是利用union select 语句&#xff0c;该语句会同时执行两条select 语句&#xff0c;实现跨库、跨表查询。 必要条件 两…

centos7安装docker-compose—及常见错误排解

目录 一、Docker-Compose概述Compose有2个重要的概念&#xff1a;一、安装docker-compose1.从github上下载docker-compose二进制文件安装 二、Docker-compose实战 二、Dcoker-compose 不好下载&#xff0c;你直接使用docker 一个一个的安装使用dockerfile安装各种服务组件 一、…

电商API接口的研发和应用!

API&#xff08;Application Programming Interface&#xff0c;应用程序编程接口&#xff09;指的是为不同的软件应用程序提供编程接口的一组协议、规则以及工具的集合&#xff0c;以便它们能够互相交互&#xff0c;实现数据通信和功能调用。API已成为了现代软件开发和商业应用…

countDown+react+hook

道阻且长&#xff0c;行而不辍&#xff0c;未来可期 知识点一&#xff1a; new Date().getTime()可以得到得到1970年01月1日0点零分以来的毫秒数。单位是毫秒 new Date().getTime()/1000获取秒数1分钟60秒&#xff0c;1小时60分钟1hour:60*60>单位是秒 60*60*1000>单位…

Gin 框架入门实战系列(一)

GIN介绍 Gin是一个golang的微框架,封装比较优雅,API友好,源码注释比较明确,具有快速灵活,容错方便等特点 对于golang而言,web框架的依赖要远比Python,Java之类的要小。自身的net/http足够简单,性能也非常不错 借助框架开发,不仅可以省去很多常用的封装带来的时间,…

Element浅尝辄止8:Tooltip 文字提示组件

常用于展示鼠标 hover 时的提示信息。 1.如何使用&#xff1f; //使用content属性来决定hover时的提示信息。 //由placement属性决定展示效果&#xff1a;placement属性值为&#xff1a;方向-对齐位置&#xff1b; //四个方向&#xff1a;top、left、right、bottom&#xff1…

C++ 强制转换运算符

强制转换运算符是一种特殊的运算符&#xff0c;它把一种数据类型转换为另一种数据类型。强制转换运算符是一元运算符&#xff0c;它的优先级与其他一元运算符相同。 大多数的 C 编译器都支持大部分通用的强制转换运算符&#xff1a; (type) expression 其中&#xff0c;type …

Java项目-苍穹外卖-Day05-Redis技术应用

1.店铺营业状态设置 需求分析和设计 左上角要求是有回显的 所以至少两个接口 1.查询营业状态接口&#xff08;分为了管理端和用户端&#xff09; 2.修改营业状态接口 因为管理端和用户端路径不同&#xff0c;所以现在是至少三个接口的 可以发现如果存到表里除了id只有一个…

C# List与HashSet的contains()方法查询速度比较

List 和HashSet同时查询40万条数据&#xff0c;谁的效率更高&#xff1f; //**1.下面是List底层源码**public boolean contains(Object o) {//如果查到我们想要查询的值则返回一个true&#xff0c;否则返回false&#xff0c;return indexOf(o) > 0;//这里是调用了indexOf方…

Kafka3.0.0版本——Leader故障处理细节原理

目录 一、服务器信息二、服务器基本信息及相关概念2.1、服务器基本信息2.2、LEO的概念2.3、HW的概念 三、Leader故障处理细节 一、服务器信息 三台服务器 原始服务器名称原始服务器ip节点centos7虚拟机1192.168.136.27broker0centos7虚拟机2192.168.136.28broker1centos7虚拟机…

智慧矿山2.0:煤矿智能化综合管理AI大数据监管平台建设方案设计

一、行业背景 能源与煤矿是我国国民经济的重要物质生产部门和支柱产业之一&#xff0c;同时也是一个安全事故多发的高危行业&#xff0c;施工阶段的现场管理对工程成本、进度、质量及安全等至关重要。煤矿智能化既是未来趋势&#xff0c;更是产业发展需求&#xff0c;建设智慧…

列表类控件虚拟化

WPF列表控件提供的最重要的功能是UI虚拟化&#xff08;WPF编程宝典说的&#xff09;。所有的WPF列表控件&#xff08;所有继承自ItemsControl的控件&#xff0c;包括ListBox、CombBox、ListView、TreeView、DataGrid&#xff09;都支持UI虚拟化。 UI虚拟化的支持实际上没有被构…

vue2.6及以下版本导入 TDesign UI组件库

TDesign 官方文档:https://tdesign.tencent.com/vue/components/button 我们先打开一个普通的vue项目 然后 如果你是 vue 2.6 或者 低于 2.6 在终端执行 npm i tdesign-vue如果你是 2.7 或者更高 执行 npm i tdesign-vuenaruto这里 我们 以 2.6为例 因为大部分人 用vue2 都是…

零知识证明的应用场景-1用户登录

零知识证明&#xff08;Zero-Knowledge Proof, ZKP&#xff09;是一种密码学方法&#xff0c;它允许一方向另一方证明某个陈述的真实性&#xff0c;而不会泄露任何有关该陈述的其他信息。这种技术在许多场景中都非常有用&#xff0c;尤其是在需要保护隐私的场合。 在身份验证的…