数据库
首页 > 数据库> > Docker部署MongoDB

Docker部署MongoDB

作者:互联网

一、查看可用的 MongoDB 版本

docker search mongo

2、拉取最新版的 MongoDB 镜像

docker pull mongo:latest

 

 3、查看本地镜像

docker images

 

4、运行容器

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

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

参数说明:

 

5、创建mongoDB账号

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

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

$ docker exec -it mongo mongo admin

 

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

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

 

 

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

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

 

二、访问容器数据库

 

 

 

 

三、容器数据持久化

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

假设,在宿主机本地创建目录:/mongo_local_data

运行容器时,指定:

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

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

如果遇到问题“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参数,恢复导入数据时,会有验证问题。

 

其他挂载方式:

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

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

标签:容器,mongo,部署,MongoDB,27017,--,Docker,data,docker
来源: https://blog.csdn.net/u013302168/article/details/121111750