Docker安装MongoDB

2023-09-19 22:20:53

1、查看当前可用版本

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

2、获取最新的mongodb镜像

docker pull mongo

3、查看镜像

docker images

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

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

5、运行容器

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

参数说明:

  • –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

7、查看mongodb日志

docker logs mongodb

8、设置mongodb随 docker 自启动

docker update mongodb --restart=always

9、查看版本

mongod --version  #查看mongo版本

10、进入mongo容器

# 创建mongo容器后,进入容器
docker exec -it mongodb /bin/bash

# 进入mongo shell
mongosh 

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}

12、认证登录

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

按Ctrl+D或输入exit退出。

13、客户端连接试试看

使用navicat连接看看

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

  • 以 admin 用户身份进入mongo

    docker exec -it mongodb mongo admin 
    
  • 认证登录(一定要)

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

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

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

15、登录haohao数据库

  • 以 admin 用户身份进入mongo
docker exec -it 11e2d2fd20a2 mongo admin
  • 对 king进行身份认证:
db.auth('king','123456')
  • 切换数据库
use haohao
  • 添加数据
db.test.save({name:"zhangsan"});
  • 查询数据
db.test.find()
更多推荐

dockerfile用ENTRYPOINT好还是用CMD好

在Dockerfile中使用`ENTRYPOINT`和`CMD`都有其用途和优劣势,具体取决于你的应用和需求。这两个指令的主要区别在于如何处理容器启动时的命令参数。1.`CMD`指令:-`CMD`用于定义容器启动时的默认命令,但它可以在运行容器时被替代。如果在运行容器时提供了命令参数,那么这些参数会覆盖`CMD`中定义

说下 RESTful API 使用的几个方法

在最近的面试中,有问到说是说一下RESTfulAPI的几个方法。这次面试问的问题还是比较多的,但是很多问题都是开放性问题,说心里话很长时间没有遇到这样比较好的沟通式面试了。不少公司,以上来就做题目,这个让人很反感。不过现在做题目的过程中,很多公司也都强调,我们不需要有完整的方案,不能运行也没有关系,主要是看思路吧。小结

C++之mutex、operator()、lambda应用总结(二百三十一)

简介:CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长!优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀人生格言:人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.更多原创,欢迎关注:Android系统攻城狮1.前言本篇目的:理解C+

总结分析 | 基于phpmyadmin的渗透测试

一、什么是phpmyadmin?phpMyAdmin是一个以PHP为基础,以Web-Base方式架构在网站主机上的MySQL的数据库管理工具,让管理者可用Web接口管理MySQL数据库。借由此Web接口可以成为一个简易方式输入繁杂SQL语法的较佳途径,尤其要处理大量资料的汇入及汇出更为方便。其中一个更大的优势在于由于p

凌恩明星产品eDNA再升级:海洋脊椎动物数据库上线!!

凌恩生物明星产品鱼类eDNA产品再次大升级!海洋脊椎动物数据库个性化定制服务上线!自建海洋脊椎动物个性化数据库,更全面的物种分类,更完善的分析内容!!eDNA宏条形码技术在海洋物种多样性调查研究中的优势明显,相比于传统的捕捞、拖网监测技术,eDNA宏条形码技术灵敏度更高,能够检出更多的海洋脊索物种,并且具有高时效性,在

MySQL缓冲池Buffer Pool

前言​在应用系统中,为加速数据访问,会把高频的数据放在「缓存」(Redis、MongoDB)里,减轻数据库的压力。在操作系统中,为了减少磁盘IO,同时为了快速响应,引入了「缓冲池」(bufferpool)机制。​MySQL作为一个存储系统,为提高性能,减少磁盘IO,同样具有「缓冲池」(bufferpool)机制。介绍​

风靡全国的真人猫抓老鼠是什么?

某音上这个词条2.6亿,小某书上1.2亿。据说已经风靡全国50多个城市了。各大新闻网站和自媒体人争相报道,热度直接拉满!现在的年轻人真会玩!仔细了解过后发现,它火是有内在原因的,现在都市工作后没有可以放松的体育项目,健身房老跑路不说,普通人很难坚持下来,那么多年轻人想要社交破圈。这游戏活动都能解决。社交+娱乐+运动,一

使用企业订货软件的担忧与考虑|网上APP订货系统

使用企业订货软件的担忧与考虑|网上APP订货系统网上订货系统担心出现的问题1,如果在订货系统中定错(多)货物了该怎么办其实这也是很多人在网购或者是现实中经常会犯的一个错误,但是网上订货平台为大家提供了很多的解决方案,其中对于订单的修改就是其中一种。我们可以将网上企业订货系统系统,想象成为一个大型的电商平台。而对于订单修

C语言之双向链表

C语言之双向链表双向链表的创建和遍历#include<stdio.h>#include<stdint.h>//定义结点结构体typedefstructstudent{//数据域intnum;//学号intscore;//分数charname[20];//姓名//指针域structstudent*front;//保存上一

WebAssembly跨平台开发

一、简介WebAssembly是一种新型的低级字节码,其设计目标是提供一种可移植的目标代码。WebAssembly可以在浏览器中运行并与JavaScript交互,可用于在Web平台上运行高性能,低延迟的应用程序,也可用于跨平台开发桌面应用、服务端应用和IoT应用程序。与JavaScript的对比,JavaScript是

[论文阅读]A ConvNet for the 2020s

摘要视觉识别的咆哮的20年代开始于ViTs的引入,它很快取代了卷积神经网络,成为最先进的图像分类模型。另一方面,一个原始的ViT在用于一般的比如目标识别和语义分割的计算机视觉任务的时候面临困难。层次Transformer(例如,Swin-Transformer),它重新引入了几个卷积神经网络先验,使Transforme

热文推荐