什么是Docker Compose?举例说明如何使用它

什么是Docker Compose?举例说明如何使用它

Docker帮助你在你的机器上快速建立一个开发环境。完成整个过程只需要几分钟时间。

但是,让我们假设你被分配到一个项目上,该项目需要至少10个不同的服务处于运行状态来运行你的项目。例如,假设你的项目需要Java 8、Node 14、MySQL、MongoDB、Ruby on rails、RabbitMQ和其他。

在这种情况下,你必须从Docker中单独提取所有这些镜像,并在其容器中启动所有这些镜像。在某些时候,一个进程可能依赖于另一个进程来运行。所以,你必须给它们排序。

如果这是一个一次性的过程就好了。但是,不仅仅是一次–每天,每次你开始在你的项目上工作时–你都必须启动所有这些服务。

这是一个乏味的过程,对吗?

为了克服这个问题,Docker引入了一个叫做多容器(Docker Compose)的概念。在学习Docker Compose之前,让我们快速了解一下如何在Docker中启动数据库主机。

在本教程的例子部分,我们将一起启动一个NodeJS容器和MongoDB容器。在一开始就学习MongoDB,会让你对我们转向Docker Compose时有一个很好的理解。

我们将把本教程分成两个部分:

  1. 如何使用docker作为数据库主机(MongoDB)?
  2. 示例说明Docker Compose如何工作(NodeJS和MongoDB)

如何使用Docker作为数据库主机

如果你有过后端开发的经验,你可能有机会处理多个数据库。例如,像MySQL/Postgres这样的数据库来处理关系型数据,Cassandra/MongoDB来处理非结构化数据。

想知道一个秘密吗?你可以在不在本地机器上安装数据库的情况下进行后端开发工作。是的,你可以使用Docker作为数据库主机。它在特定的镜像文件中默认拥有所有的依赖项。

为什么我们需要Docker数据库?

Docker帮助我们在不同的平台和环境中保持一致的版本。假设你的团队中有一群人在MongoDB 5.0版本上工作。如果一个新成员加入你的团队,他们需要用精确的配置手动设置相同的版本。如果他们安装了最新版本的MongoDB(6.0)呢?这将导致一些冲突。如果它蔓延到其他人的设备上,这将是一场噩梦。

为了解决这个问题,你可以在Docker中使用带有自定义配置的MongoDB,并将MongoDB镜像推送到Docker Hub内部。如果有新人进来,他们可以拉动镜像并开始实施,而无需任何手动配置。

让我们来看看在Docker中使用数据库的优势。

  1. 通过使用这种实现方式,我们可以确保团队中的每个人都使用准确的运行时间和配置,而不需要任何外部资源。
  2. 它非常容易设置,我们可以使用Docker桌面快速启动/停止服务器

如何使用Docker设置MongoDB

如果你不熟悉Docker Hub,这里有一个简短的介绍。Docker hub是一个平台,你可以在这里找到并分享公开或私有的Docker镜像。它与GitHub / GitLab非常相似。简而言之,它是一个Docker镜像的储存库。

第一步,从Docker Hub拉出官方的Docker镜像。

MongoDB镜像

Docker Hub中的MongoDB镜像

 

docker pull mongo:latest

从Docker Hub拉取Mongo镜像的终端命令

拉取Mongo镜像的输出示例

从Docker Hub拉取Mongo镜像的输出示例

一旦你完成了Mongo镜像的拉取,打开你的Docker桌面,你就可以看到它了。

Docker桌面中的可用Mongo镜像

Docker桌面中的可用Mongo镜像

让我们使用 docker run 命令来运行我们的MongoDB镜像。

docker run -d -p 27017:27017 --name mongo-server-local mongo: latest

在docker中运行mongodb的命令

运行mongodb的命令

在docker中运行mongodb的命令

我们已经成功运行了Docker镜像。现在我们可以看到容器在Docker桌面上运行。

运行的Mongo容器

在Docker Desktop中运行的Mongo容器

所以,MongoDB服务器正在你的机器上运行。让我们在浏览器中确认这一点。在你的浏览器上进入http://localhost:27017,你应该能够看到如下截图所示的信息:

使用Docker运行MongoDB服务器

使用Docker运行MongoDB服务器时,”看起来你正试图通过HTTP访问MongoDB的本地驱动端口” 的输出示例

有意思吧?

我们可以随时使用Docker停止/启动MongoDB服务器。

重要说明

  1. 不建议将Docker作为生产用数据库使用
  2. 不要在大规模应用中使用Docker数据库

什么是docker-compose?

让我们再来看看docker-compose。

Docker Compose是一个工具,你可以用来定义和分享多容器应用程序。这意味着你可以使用一个单一的资源来运行一个具有多个容器的项目。

例如,假设你正在用NodeJS和MongoDB一起构建一个项目。你可以创建一个单一的镜像,将两个容器作为一个服务来启动–你不需要分别启动每个容器。

有意思吧?这就解决了我在本文一开始就提出的问题。

为了实现这个目标,我们需要定义一个 docker-compose.yml

docker-compose.yml文件

compose文件是一个YML文件,定义了Docker容器的服务、网络和卷。有几个版本的compose文件格式可用–1、2、2.x和3.x。

在进一步开展工作之前,这里有一个Docker Compose团队给我们的重要说明。

从2023年6月底开始,Compose V1将不再被支持,并将从所有Docker桌面版本中移除。

我们在本文中使用的是版本3。

version: '3'
services:
app:
image: node:latest
container_name: app_main
restart: always
command: sh -c "yarn install && yarn start"
ports:
- 8000:8000
working_dir: /app
volumes:
- ./:/app
environment:
MYSQL_HOST: localhost
MYSQL_USER: root
MYSQL_PASSWORD: 
MYSQL_DB: test
mongo:
image: mongo
container_name: app_mongo
restart: always
ports:
- 27017:27017
volumes:
- ~/mongo:/data/db
volumes:
mongodb:

使用docker compose运行多个容器的命令

让我们来拆解一下上面的代码,并逐一理解它:

  • version 指的是docker-compose的版本(最新的3)。
  • services 定义了我们需要运行的服务
  • app 是你的一个容器的自定义名称
  • image 指的是我们要拉的镜像。这里我们使用的是 node:latest 和 mongo.
  • container_name 是每个容器的名称
  • restart 启动/重启一个服务容器
  • port 定义了运行该容器的自定义端口
  • working_dir 是服务容器的当前工作目录
  • environment 定义了环境变量,如DB凭证等。
  • command 是运行服务的命令

如何运行多容器

我们需要使用docker build来构建我们的多容器。

docker compose build

构建docker-compose.yml的命令

成功构建后,我们可以使用 up 命令来运行容器。

docker compose up

使用docker-compose运行多个容器的命令

如果你想以分离模式运行容器,只需使用 -d 标志。

docker compose up -d

使用docker-compose以分离模式运行多个容器的命令

以分离模式运行多个容器

使用docker-compose以分离模式运行多个容器的输出示例

好了,我们可以开始了。容器已经启动并运行了。让我们检查一下容器列表。

docker compose ps

列出正在运行的容器服务的命令

列出运行中的容器服务

列出运行中的容器服务的输出样本

好耶,我们可以看到有两个容器在同时运行。

使用docker运行nodejs服务

使用docker运行nodejs服务的输出样本

使用docker运行mongodb服务

使用docker运行mongodb服务的输出样本

为了查看MongoDB中的数据,你必须安装MongoDB Compass。

下面是它的屏幕截图。

MongoDB服务器视图

mongodb compass中的MongoDB服务器视图

小结

在这篇文章中,你已经通过一个例子了解了Docker Compose是如何工作的。使用多个容器,你可以旋转任何类型的服务,如RabbitMQ或Apache Kafka,并在一个单一的服务源中运行。希望你喜欢阅读这篇文章。

评论留言