docker+mongodb设置数据库的账号和密码

1、在docker宿主机构建mongodb数据持久化目录

css 复制代码
# 数据文件
mkdir -p /usr/local/mongodb/data

# 日志文件
mkdir -p /usr/local/mongodb/log

2、拉取镜像, 选择官方版本(亲测16.x版本的mongodb不可用,可安装指定版本)

css 复制代码
docker search mongo 
docker pull mongo:latest // 拉取最新版
或
docker pull mongo:版本号// 拉取指定版本

3、基于镜像创建容器并设置数据持久化

参数介绍

1、取容器名
--name <image_name>

2、端口映射(宿主机端口:容器端口)
-p <host_port>:<container_port><host_ip>:<host_port>:<container_port>

3、将主机的目录或文件挂载到容器
-v <host_path>:<container_path>

4、在后台(守护进程)模式下运行容器
-d

5、以指定版本的镜像创建容器
镜像名:版本号

6、在MongoDB容器中启用身份验证
--auth

css 复制代码
docker run --name mongo-01 -p 27017:27017 -v /usr/local/mongodb/data:/data/db -v /usr/local/mongodb/log:/data/log -d mongo:5.0.19  --auth

4、进入容器并启动容器终端

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

5、mongodb账号密码设置

css 复制代码
// 进入mongo shell, 进入失败可能是mongo版本有问题,换个低版本的镜像再走一遍前面的流程,这里的版本是5.0.19
mongo

// 进入admin数据库, 使用`use 数据库名`,如果数据库名不存在则会新建一个
use admin

// 创建超级权限root角色的用户,或者角色权限比较大的用户
// 用户名:slj, 密码:sljpwd, 角色root
db.createUser({
  user: "slj",
  pwd: "sljpwd",
  roles: [
    { role: "root", db: "数据库名" }, // db不设置将应用于所有数据库
    // 其他角色...
  ] 或 roles: ['root']
})

// 验证用户名和密码是否设置成功, 打印1则代表认证通过
// db.auth('用户名', '密码')

db.auth('slj','sljpwd')

6、退出shell使用exit

相关推荐
ID_180079054738 小时前
(淘宝 / 京东)商品评论 API 接口:技术实战案例与架构分析
服务器·数据库·架构
爱莉希雅&&&8 小时前
Zabbix监控初步搭建
linux·运维·数据库·mysql·zabbix
狼与自由8 小时前
mysql到clickhouse
数据库·mysql·clickhouse
六月雨滴8 小时前
Oracle 数据库之归档日志
数据库·oracle·dba
土狗TuGou8 小时前
SQL内功笔记 · 第6篇:窗口函数的使用ROW_NUMBER等
java·数据库·后端·sql·mysql
川石课堂软件测试8 小时前
使用mock进行接口测试教程
数据库·python·功能测试·测试工具·华为·单元测试·appium
ai产品老杨8 小时前
基于 Docker 容器化与异构计算的智能安防架构:解耦 GB28181/RTSP 协议与多芯片适配,源码交付如何助力集成商节省 95% 开发成本?
docker·容器·架构
Solis程序员8 小时前
MongoDB 超全入门到实战:从原理、CRUD到高可用架构
数据库·mongodb·架构
yurenpai(27届找实习中)8 小时前
redis_点评(26.附近店铺——实现附近商家功能)
数据库·spring boot·redis
BullSmall8 小时前
异构数据库(通俗 + 核心知识点)
数据库