• Docker安装MongoDB


    1、查看当前可用版本

    docker search mongo #通过该命令查看可用的MongoDB版本
    
    • 1

    2、获取最新的mongodb镜像

    docker pull mongo
    
    • 1

    也可以指定版本

    docker pull mongo:6.0
    
    • 1

    3、查看镜像

    docker images
    
    • 1

    4、在宿主机上创建需要挂载的文件

    #创建文件在 /docker目录下
    mkdir -p /docker/mongodb/{data,logs} 
    #在准备挂载的目录下创建并修改目录权限
    chmod -R 777 /docker/mongodb
    
    • 1
    • 2
    • 3
    • 4

    5、运行容器

    docker run --name mongodb -p 27017:27017 -v /docker/mongodb/data:/data/db -v /docker/mongodb/log:/data/log -d mongo --auth
    
    • 1

    参数说明:

    • –name mongodb 运行容器名

    • -p 27017:27017:将27017映射到外部端口27017将容器的27017端口映射到主机的27017端口,27017是和宿主机的通信接口,所有docker内部容器的连接使用27017接口,集群配置需连接容器内部27017端口,故最好保持前后端口一致

    • -v /docker/mongodb/data:/data/db -v /docker/mongodb/log:/data/log 挂载目录

    • -d 后台运行容器

    • mongo mongo 镜像名 也可使用镜像id

    • –auth 需要验证就加,不需要验证,就去掉。默认mongodb是不使用用户认证

    6、查看是否运行成功

    docker ps
    
    • 1

    7、查看mongodb日志

    docker logs mongodb
    
    • 1

    8、设置mongodb随 docker 自启动

    docker update mongodb --restart=always
    
    • 1

    9、查看版本

    #查看mongo版本
    mongod --version  
    
    • 1
    • 2

    10、进入mongo容器

    # 创建mongo容器后,进入容器
    docker exec -it mongodb /bin/bash
    
    # 进入mongo shell
    mongosh 
    
    • 1
    • 2
    • 3
    • 4
    • 5

    也可以一行命令进入

    docker exec -it mongodb mongosh 
    
    • 1

    11、为MongoDB添加管理员用户

    # 进入admin数据库
    use admin
    
    # 创建超级权限root角色的用户,或者userAdminAnyDatabase 等角色权限比较大的用户,我创建的是拥有超级权限root角色的用户root
    # 用户名:root,密码:root,角色(权限):root,数据库:admin
    db.createUser({user:'root',pwd:'123456',roles:[{role:'root',db:'admin'}]})
    
    #6.0之后创建成功返回的成功标识为:{ok:1}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    12、认证登录

    # 认证登录db.auth('用户名','密码'),打印1则代表认证通过
    db.auth('root','123456')
    
    • 1
    • 2

    按Ctrl+D或输入exit退出。

    13、客户端连接试试看

    使用navicat连接看看
    
    • 1

    14、创建普通用户、密码和数据库

    • 以 admin 用户身份进入mongo

      #这里的mongodb是容器名
      docker exec -it mongodb mongosh admin 
      
      • 1
      • 2
    • 认证登录(一定要)

      db.auth('root','123456')
      
      • 1
    • 创建 用户、密码和数据库

      db.createUser({ user: 'king', pwd: '123456', roles: [ { role: "readWrite", db: "mongo_test" }]})
      
      • 1

      user:为登录时的用户名
      pwd:为登录时的密码
      roles中的内容:role为权限此处为读写权限 db为数据库名

    15、登录mongo_test数据库

    • 以 admin 用户身份进入mongo

      docker exec -it mongodb mongosh admin
      
      • 1

      在这里插入图片描述

    • 对 king进行身份认证:

      db.auth('king','123456')
      
      • 1

      在这里插入图片描述

    • 切换数据库

      use mongo_test
      
      • 1

      在这里插入图片描述

    • 添加数据

      #这里的test是隐式创建的集合名
      db.test.insert({name:"zhangsan"});
      
      • 1
      • 2

      在这里插入图片描述

    • 查询数据

      db.test.find()
      
      • 1

      在这里插入图片描述

  • 相关阅读:
    MindSpore处理自定义数据集的时候报错
    hot100----字串
    K8S:kubectl陈述式及声明式资源管理
    c语言第一课---------它来了,它来了,带着薪资走来了
    .NET Core剪裁器Zack.DotNetTrimmer升级瘦身引擎,并支持剪裁计划的录制和回放
    Flink TaskManager 内存管理机制与调优
    Day 00 python基础认识与软件安装
    2023年最新版Apollo保姆级使用手册(超级详尽版本)
    Python的pytest框架(6)--测试钩子 (hooks)
    Angular变更检测机制
  • 原文地址:https://blog.csdn.net/qq_56265207/article/details/133049095