Docs 菜单
Docs 主页
/ /
Atlas CLI
/ /

使用 Docker 创建本地 Atlas 部署

在此页面上

  • 使用 Docker 创建本地 Atlas 部署
  • 使用 Docker Compose 创建本地 Atlas 部署
  • 使用 Docker Compose 在运行中持久保存数据
  • 生成依赖项列表
  • 验证映像签名
  • 使用Github操作运行映像
  • 将官方映像转换为本地Atlas部署

本教程向您展示如何使用 Docker 创建本地 Atlas 部署。 在本教程中,我们将使用 Docker 部署单节点副本集。

重要

公开预览版

Docker和Docker Compose 中的本地部署以公共预览版形式提供。 在公共预览阶段,该功能和相应的文档可能随时更改。 要提问和提供反馈,请参阅 Atlas CLI本地开发社区论坛。

1

要了解更多信息,请参阅 Docker 文档。

2

示例:

docker pull mongodb/mongodb-atlas-local:latest
3

示例:

docker run -p 27017:27017 mongodb/mongodb-atlas-local
docker run -e MONGODB_INITDB_ROOT_USERNAME=user -e MONGODB_INITDB_ROOT_PASSWORD=pass -p 27017:27017 mongodb/mongodb-atlas-local

日志会在 Docker 映像运行时显示。

4

要从主机(而不是容器)连接到本地Atlas部署,请将以下命令复制并粘贴到新终端中,并将 {connection_string} 变量替换为您的连接string 。

注意

以下示例使用mongosh ,但您可以使用自己喜欢的连接方法。

mongosh {connection_string}

例子:

mongosh "mongodb://localhost:27017/?directConnection=true"
mongosh "mongodb://user:pass@localhost:27017/?directConnection=true"

使用 Docker Compose 创建本地 Atlas 部署。

注意

如果您现有使用官方MongoDB Docker映像构建的基于 Docker-Compose 的Atlas实施,并且您希望将其转换为使用Atlas本地开发者映像,请参阅下面的转换为本地开发者实施。

1

要了解更多信息,请参阅 Docker 文档。

2

示例:

brew install docker-compose

要了解更多信息,请参阅 Docker Compose 安装文档。

3

在运行 Docker Compose 的同一目录中创建docker-compose.yaml文件。

示例:

1services:
2 mongodb:
3 image: mongodb/mongodb-atlas-local
4 environment:
5 - MONGODB_INITDB_ROOT_USERNAME=user
6 - MONGODB_INITDB_ROOT_PASSWORD=pass
7 ports:
8 - 27018:27017
4

以下命令创建启用 Atlas Search 功能的本地 Atlas 部署。

示例:

docker-compose up
5

要从主机(而不是容器)连接到本地Atlas部署,请将以下命令复制并粘贴到新终端中,并将 {connection_string} 变量替换为您的连接string 。

注意

以下示例使用mongosh ,但您可以使用自己喜欢的连接方法。

mongosh {connection_string}

示例:

mongosh "mongodb://user:pass@localhost:27018/?directConnection=true"
6
docker compose down -v

您可以使用 Docker Compose 在多次运行中持久保存数据 。持久化数据有助于确保数据在运行之间不会丢失。 数据在 Docker Compose 运行期间保持可用。

1

要了解更多信息,请参阅 Docker 文档。

2

示例:

brew install docker-compose

要了解更多信息,请参阅 Docker Compose 安装文档。

3

更新docker-compose.yaml文件以将必要的数据目录挂载为卷。

示例:

1services:
2 mongodb:
3 hostname: mongodb
4 image: mongodb/mongodb-atlas-local
5 environment:
6 - MONGODB_INITDB_ROOT_USERNAME=user
7 - MONGODB_INITDB_ROOT_PASSWORD=pass
8 ports:
9 - 27019:27017
10 volumes:
11 - data:/data/db
12 - config:/data/configdb
13volumes:
14 data:
15 config:
4

以下命令创建启用 Atlas Search 功能的本地 Atlas 部署。

示例:

docker-compose up

您还可以在 分离模式下运行 Docker Compose。

示例:

docker-compose up -d
5

要从主机(而不是容器)连接到本地Atlas部署,请将以下命令复制并粘贴到新终端中,并将 {connection_string} 变量替换为您的连接string 。

注意

以下示例使用mongosh ,但您可以使用自己喜欢的连接方法。

mongosh {connection_string}

示例:

mongosh "mongodb://user:pass@localhost:27019/?directConnection=true"

您可以为mongodb/mongodb-atlas-local Docker 映像生成依赖项列表。

1

示例:

brew install syft

要了解更多信息,请参阅 syft 自述文件。

2
syft mongodb/mongodb-atlas-local

您可以验证mongodb/mongodb-atlas-local Docker 映像的签名。

1

示例:

brew install cosign

要了解更多信息,请参阅 cosign 安装。

2

示例:

curl -O https://cosign.mongodb.com/mongodb-atlas-local.pem
COSIGN_REPOSITORY="docker.io/mongodb/signatures" cosign verify --private-infrastructure --key=./mongodb-atlas-local.pem "mongodb/mongodb-atlas-local";

要使用mongodb/mongodb-atlas-localDocker Github操作运行 映像,请创建一个工作流程文件。要了解更多信息,请参阅Github Actions 快速入门。

示例:

.github/workflows目录中创建以下mongodb.yml文件:

on:
push:
branches:
- main
pull_request:
jobs:
run:
runs-on: ubuntu-latest
services:
mongodb:
image: mongodb/mongodb-atlas-local
ports:
- 27017:27017
steps:
- name: install mongosh
run: |
curl --output mongosh.deb https://downloads.mongodb.com/compass/mongodb-mongosh_2.2.1_amd64.deb
sudo dpkg -i mongosh.deb
mongosh --version
- run: mongosh 'mongodb://localhost/?directConnection=true' --eval 'show dbs'

如果您有在Docker Compose 中运行的现有Atlas实施,并且该实施是使用官方Mongo Docker映像构建的,则可以参考以下清单,以简化将其转换为 mongodb-atlas-local 映像的过程。

  1. docker-compose.yaml文件中删除任何现有的 command。由于Docker Compose 定义中的 command 会覆盖 mongodb-atlas-local 映像中定义的 ENTRYPOINT,因此您必须删除任何现有的 commandmongodb-atlas-local 映像才能按设计运行。

  2. 无需为Atlas部署定义运行状况检查,因为此功能内置于 mongodb-atlas-local 映像中。

以下示例说明了可能需要对Docker Compose YAML文件进行的更改:

services:
self_built_atlas_implementation:
image: mongo:8.0
ports:
- 27017:27017
command: ["./entrypoint.sh"] # You may have defined a health check for the database in the entrypoint script.
services:
local_dev_atlas:
image: mongodb/mongodb-atlas-local:8.0
hostname: local_dev_atlas
ports:
- 27017:27017
environment:
- MONGODB_INITDB_ROOT_USERNAME=user
- MONGODB_INITDB_ROOT_PASSWORD=pass
volumes:
- data:/data/db
- config:/data/configdb
volumes:
- data:
- config:

后退

创建本地部署