docker使用mongodb的方法
这篇文章将为大家详细讲解有关docker使用mongodb的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
介绍如何在docker中使用MongoDB。
如果你是一名MongoDB的初学者,那么你入门MongoDB的第一件事就是安装MongoDB,但是安装MongoDB又不是一件简单的事情,还需要自己配置一些服务。这时候,docker就能帮上大忙,它能够让你不需要本地安装MongoDB就能使用MongoDB。下面让我们来看看这是怎么实现的。
首先你的电脑上需要安装docker,然后在docker的镜像中查询MongoDB的镜像,命令如下:
dockersearchmongodb
输出的结果如下:
NAMEDESCRIPTIONSTARSOFFICIALAUTOMATEDmongoMongoDBdocumentdatabasesprovidehighavai…5606[OK]mongo-expressWeb-basedMongoDBadmininterface,writtenw…386[OK]tutum/mongodbMongoDBDockerimage–listensinport27017…224[OK]bitnami/mongodbBitnamiMongoDBDockerImage83[OK]percona/percona-server-mongodbPerconaServerforMongoDBdockerimages23frodenas/mongodbADockerImageforMongoDB17[OK]centos/mongodb-32-centos7MongoDBNoSQLdatabaseserver5centos/mongodb-26-centos7MongoDBNoSQLdatabaseserver5eses/mongodb_exportermongodbexporterforprometheus4[OK]centos/mongodb-36-centos7MongoDBNoSQLdatabaseserver4quadstingray/mongodbMongoDBwithMemoryandUserSettings3[OK]bigtruedata/php-mongodbPHPimagewithMongoDBsupport2[OK]neowaylabs/mongodb-mms-agentThisDockerimagewithMongoDBMonitoringAg…2[OK]tozd/mongodbBaseimageforMongoDBserver.2[OK]nuxeoapbcatalog/nuxeo-mongodb-apbMongoDBdeploymentforNuxeo1[OK]openshift/mongodb-24-centos7DEPRECATED:ACentos7basedMongoDBv2.4ima…1centos/mongodb-34-centos7MongoDBNoSQLdatabaseserver1webhippie/mongodbDockerimagesformongodb1[OK]perconalab/percona-server-mongodb-operatorMOVEDTOhttps://hub.docker.com/r/perconalab…1phenompeople/mongodbMongoDBisanopen-source,documentdatabas…0[OK]gebele/mongodbmongodb0[OK]mongodbsap/mongodbdocker0targetprocess/mongodb_exporterMongoDBexporterforprometheus0[OK]ansibleplaybookbundle/mongodb-apbAnAPBtodeployMongoDB.0[OK]xogroup/mongodb_backup_gdriveDockerimagetocreateaMongoDBdatabaseba…0[OK]
我们在这些镜像中选择使用第一个镜像,即mongo, 拉取mongo镜像,命令如下:
dockerpullmongo
查看该镜像的信息:
dockerimagesmongo
输出的结果如下:
REPOSITORYTAGIMAGEIDCREATEDSIZEmongolatest0da05d84b1fe2weeksago394MB
现在,在docker中已经存在MongoDB的镜像mongo,接下来我们将使用这个镜像。输入命令:
dockerrun-p27000:27017-v$PWD/db:/data/db-dmongo:latest
其中, -p 参数为端口映射,格式为:主机(宿主)端口:容器端口,-v参数为数据卷挂载,将主机的目录$PWD/db 映射到容器的/data/db,这是为了存储MongoDB操作时的数据,-d参数表示后台运行。
接着输入以下命令查询正在运行的docker容器:
dockerps
输出如下:
CONTAINERIDIMAGECOMMANDCREATEDSTATUSPORTSNAMES9664a5056e78mongo:latest"docker-entrypoint.s…"3secondsagoUp2seconds0.0.0.0:27017->27017/tcpnervous_heyrovsky
接着运行以下命令,即可使用docker中的虚拟机,该虚拟机已帮你安装好MongoDB,可以直接使用:
dockerexec-it9664a5056e78bash
在虚拟机中输入mongo ,界面如下:
以下将展示一些MongoDB的基础操作,具体的入门教程可以参考:https://blog.csdn.net/jclian91/article/details/78654274 。
显示数据库:
>showdbsadmin0.000GBconfig0.000GBlocal0.000GB
创建新数据库及集合:
>useschoolswitchedtodbschool>db.createCollection('teacher'){"ok":1}>showdbsadmin0.000GBconfig0.000GBlocal0.000GBschool0.000GB
往集合中插入新文档:
>db.teacher.insert({id:1,name:'zhangshan',age:38})WriteResult({"nInserted":1})>db.teacher.insert({id:2,name:'lisi',age:47})WriteResult({"nInserted":1})>db.teacher.insert({id:3,name:'wangwu',age:26})WriteResult({"nInserted":1})
查询文档:
>db.teacher.count()3>db.teacher.find(){"_id":ObjectId("5c6d12d880b47c18564d99a7"),"id":1,"name":"zhangshan","age":38}{"_id":ObjectId("5c6d12df80b47c18564d99a8"),"id":2,"name":"lisi","age":47}{"_id":ObjectId("5c6d12e580b47c18564d99a9"),"id":3,"name":"wangwu","age":26}>db.teacher.find({name:'lisi'}){"_id":ObjectId("5c6d12df80b47c18564d99a8"),"id":2,"name":"lisi","age":47}
此时,在MongoDB的可视化软件Robo 3T中,依然能够看到我们插入的数据,只是连接的端口改为27000,如下图:
关于docker使用mongodb的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。