docker创建带auth验证的mongodb数据库

本文详细介绍如何在MongoDB中设置认证及创建不同权限级别的用户,包括root用户和普通用户,并演示了基本的操作流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

记录本身,即已是反抗

首先下载mongo镜像,简单命令不做过多叙述,前面文章有介绍怎么基本使用docker。 之后编写docker-compose.yml文件,运行 docker-compose up -d生成容器并后台启动。

root创建

// docker-compose.yml
// command:启动是的命令行参数,添加认证auth
version: '2'
services:
  mongodb:
    image: mongo
    ports:
        - 27017:27017
    volumes:
        - "./data/configdb:/data/configdb"
        - "./data/db:/data/db"
    command: mongod --auth
    tty: true
复制代码

运行docker ps查看容器是否运行。

进入docker容器并进入mongo命令行。

docker exec -it 4 /bin/bash
mongo
复制代码

此时show dbs无法执行,需要认证。 切换到admin并创建root用户:

use admin
db.createUser({ user: 'root', pwd: 'root', roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] })
复制代码

如上,可以看到root用户创建成功。 exit退出mongo命令行,带验证的mongodb已经创建成功。

普通用户创建

接下来创建普通用户,并演示验证。 再次执行mongo 进入mongodb命令行。

可以看到root用户验证成功,并且可以查看数据库。

下面创建普通用户,和创建root用户基本一致,只是角色不同 。

//拥有对数据库app的读写权限。
use app
db.createUser(
  {
    user: "swen",
    pwd: "swen",
    roles: [ { role: "readWrite", db: "app" }
             ]
  }
)
复制代码

创建成功并 exit退出,swen用户可以对(只能对)app进行操作。 下面做基本演示。

基本验证:

演示往 test集合插入简单数据,并查看数据库状态。

介绍到此完毕。 参考资料: MongoDB 用户名密码登录
MongoDB 常用基本命令

github: github.com/yunshuipiao

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值