1、查看可用的 MongoDB 版本
docker search mongo
2、拉取最新版的 MongoDB 镜像
docker pull mongo:latest
docker pull mongo:4.4.0
3、查看本地镜像
docker images
4、运行容器
安装完成后,我们可以使用以下命令来运行 mongo 容器:
(1)数据未持久化
/root/yk/compose/mongodb/data/db
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
docker run --name mongo -v /home/db/mongo/data:/data/db --rm -d -p 27017:27017 mongo --auth
参数说明:
-itd 交互后台运行容器
–name 自定义容器名称
-p 27017:27017 容器服务的 27017 端口映射到宿主机的 端口 27017,那么外部可以通过 宿主机 IP:27017 访问容器内 mongo。
镜像名
–auth 需要密码才能访问容器服务。
docker exec -it mongodb /bin/bash
docker exec -it mongo mongo admin
biz_mongo 对应业务mongodb名称
docker exec -it mongo /bin/bash
docker exec -it 1e3744d772ae /bin/bash
5、创建mongoDB账号
首先创建一个admin用户,它的角色(role)是root,示例代码:
use admin
db.createUser({user: "admin",pwd: "password",roles: [ { role: "root", db: "admin" } ]});
use admin
db.createUser({user: "admin",pwd: "admin123!@#",roles: [ { role: "root", db: "admin" } ]});
exit;
关闭客户端连接,重新启动MongoDB,用admin登录
创建其他角色的用户,比如我想要的读写数据库db01数据库的用户user01,密码设置为pwd01
docker exec -it mongo mongo admin
db.auth('admin', 'admin123!@#')
use root
db.createUser({user: "root", pwd: "123456",roles: [ { role: "readWrite", db: "root" } ] });
db.createUser({user: "root", pwd: "123456",roles: [ { role: "readWrite", db: "admin" } ] });
db.createUser({user: "root", pwd: "123456",roles: [ { role: "readWrite", db: "yk" } ] });
db.createUser({user: "root", pwd: "123456",roles: [ { role: "readWrite", db: "admin" } ] });
db.createUser({user: "root", pwd: "123456",roles: [ { role: "readWrite", db: "admin" } ] });
最后我们可以通过 docker ps 命令查看容器的运行信息:
(1)进入容器创建数据库访问用户账号密码,并且尝试连接。
docker exec -it mongo mongo admin
docker exec -it 容器ID mongo admin
(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
原文链接:https://blog.csdn.net/u013302168/article/details/121111750