docker安装mongodb

创建目录

mkdir -p /mydata/mongodb/data/db /mydata/mongodb/data/log /mydata/mongodb/data/config

compose

version: '3.8'
services:
  mongo:
    container_name: mongo
    image: mongo:5.0 # 可以修改为自己需要的版本
    restart: always
    ports:
     - 27017:27017
    volumes:
     - /etc/localtime:/etc/localtime # 时区
     - /mydata/mongodb/data/db:/data/db # 挂载数据目录
     - /mydata/mongodb/data/log:/var/log/mongodb  # 挂载日志目录
     - /mydata/mongodb/data/config:/etc/mongo  # 挂载配置目录

启动

docker-compose -f mongodb-compose.yaml up -d

配置用户和库

进入容器

docker exec -it mongo /bin/bash

root用户

# 登录
mongo admin
# 查看当前所在数据库,默认在admin数据库
use admin
# 创建root用户,本质:为root用户赋予userAdminAnyDatabase角色作用在admin数据库上,为root用户赋予readWriteAnyDatabase角色作用再所有数据库上
db.createUser(
  {
    user: 'root',
    pwd: 'root_pwd', 
    roles: [ { role: "userAdminAnyDatabase", db: "admin" }, "readWriteAnyDatabase" ]
  }
)

普通用户(自定义库)

# 登录
mongo admin
# 查看当前所在数据库,默认在admin数据库
use xcrj_db
# 创建root用户,本质:为xcrj用户赋予dbOwner角色作用在xcrj_db数据库上
db.createUser({ user:'xcrj_user',pwd:'xcrj_pwd',roles:[ { role:'dbOwner', db: 'xcrj_db'}]})
# 退出mongo
exit;
# 登录
mongo xcrj_db -u xcrj_user -p
# 查看当前db
db

用户权限

root包含角色readWriteAnyDatabase、dbAdminAnyDatabase、userAdminAnyDatabase、clusterAdmin、restore和backup联合之后所有的权限。
dbOwner在当前db中执行任意操作
userAdmin用户管理,在当前db中管理user的权限
read只读数据权限
readWrite读写数据权限

作者声明

如有问题,欢迎指正!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值