Docker部署MongoDB

18 篇文章 2 订阅
17 篇文章 2 订阅

1、查看可用的 MongoDB 版本

docker search mongo

2、拉取最新版的 MongoDB 镜像

docker pull mongo:latest

 

 3、查看本地镜像

docker images

4、运行容器

安装完成后,我们可以使用以下命令来运行 mongo 容器:

(1)数据未持久化

docker run -itd --name mongo -p 27017:27017 mongo --auth

(2)数据持久化

docker run --name my_mongo -v /mongo_local_data:/data/db --rm -d -p 27017:27017 mongo

参数说明:

  • -itd  交互后台运行容器
  • --name 自定义容器名称
  • -p 27017:27017  容器服务的 27017 端口映射到宿主机的 端口 27017,那么外部可以通过 宿主机 IP:27017 访问容器内 mongo。
  • 镜像名
  • --auth 需要密码才能访问容器服务。

5、创建mongoDB账号

最后我们可以通过 docker ps 命令查看容器的运行信息:

(1)进入容器创建数据库访问用户账号密码,并且尝试连接。

docker exec -it mongo mongo admin

docker exec -it 容器ID mongo admin

linux

mac 

(2)执行mongoDB语句, 创建mongoDB账号

db.createUser({ user:'admin',pwd:'123456',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});

(3)使用创建账号进行连接

db.auth('admin', '123456')

 

二、访问容器数据库

 

三、容器数据持久化

没做数据持久化的话,容器内的数据随着容器关闭而消失,解决方法是把容器内的目录映射到本地,这样容器即使容器停止、不小心删除了数据也仍然在。

1.在宿主机本地创建目录:/mongo_local_data,执行命令

# 创建卷
docker volume create mongo_local_data
# 运行景相融弄个器
docker run --name my_mongo -v /mongo_local_data:/data/db --rm -d -p 27018:27017 mongo

/data/db是镜像mongo容器内的存储数据的目录

/mongo_local_data是物理机生成的数据持久化目录

运行容器命令后,自动生成物理机数据持久化目录

cd /
ls -l

【window 、mac】

如果遇到问题“docker: Error response from daemon: Mounts denied:

The path /mongo_local_data is not shared from the host and is not known to Docker.

You can configure shared paths from Docker -> Preferences... -> Resources -> File Sharing.

See https://docs.docker.com/docker-for-mac for more info.”

按照报错提示,需要将容器内指定目录,挂载到主机上!

 解决办法:

(1)客户端界面化挂载方式

 (2)命令行方式

①创建卷

docker volume create 卷名

docker volume ls

docker volume inspect 卷名

②用该卷创建一个容器

docker run -d --name=容器名称 -v 卷名:容器路径 镜像名
docker run -itd --name my_mongo -v mongo_local_data:/data/db --restart=always -p 27018:27017 mongo

③进入容器内持久化的目录

docker exec -it 11b4e9c8b3bc bash -c "cd /data/db&& ls"

 可视化界面查看卷目录

下图为mongodb容器内的数据存放目录:

注意:启动时,参数如果加--auth参数,恢复导入数据时,会有验证问题。

2.其他数据持久化挂载方式:

docker run -d --name=容器名称 --mounts src=卷名,dst=容器路径 镜像名

docker run -d --name=mongo --mounts src=mongo_local_data,dst=/data/db mongo

  • 8
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
使用Docker部署MongoDB有以下几个步骤: 1. 首先,你需要获取最新的MongoDB镜像。可以使用以下命令来获取最新的镜像: ``` docker pull mongo:latest ``` 2. 接下来,创建一个目录用于存储MongoDB的数据文件。可以使用以下命令创建目录: ``` mkdir -p /export/server/docker/mongodb/data ``` 3. 运行MongoDB容器并进行映射和认证设置。可以使用以下命令运行镜像: ``` docker run --name mongodb -v /export/server/docker/mongodb/data:/data/db -d -p 27017:27017 mongo --auth ``` 这个命令中,`-v`参数用于将宿主机的目录映射到容器内的目录,以实现数据持久化。`-p`参数用于将容器内的端口映射到宿主机上,以便在宿主机上连接MongoDB。`--auth`参数表示需要密码才能访问容器服务。 4. 使用Mongo Shell连接到MongoDB容器并切换到admin数据库。可以使用以下命令: ``` docker exec -it mongodb /bin/mongosh admin ``` 或者 ``` docker exec -it mongodb /bin/bash /bin/mongosh admin ``` 这个命令将以Mongo Shell的方式进入容器,并切换到admin数据库。 5. 创建一个管理员用户并授予相应的权限,并使用新创建的用户进行登录。可以使用以下命令: ``` db.createUser({ user:'admin',pwd:'123456',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]}); db.auth('admin', '123456') ``` 这个命令将创建一个名为admin的用户,并赋予userAdminAnyDatabase和readWriteAnyDatabase的角色,然后使用新创建的用户进行登录。 6. 进行一些基本的测试操作,比如查看数据库和表,并插入一条数据。可以使用以下命令: ``` show databases # 查看所有数据库 show tables # 查看所有表(集合) use test # 切换到test数据库(如果不存在则自动创建) db.test.insert( { _id: 1, name: "kudaren", age: "29" } ) # 插入数据 db.test.find(); # 查询数据 ``` 7. 最后,你可以使用适合你的客户端工具连接到MongoDB进行操作。 总结:Docker部署MongoDB需要先获取最新的镜像,创建数据文件存储目录,运行镜像并进行映射和认证设置,然后使用Mongo Shell连接到容器并进行操作,最后可以使用客户端工具连接到MongoDB进行管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liyinchi1988

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值