前言
有了docker,基本上就告别了各种软件、数据库的安装,直接从镜像库pull下来,爽,想想以前那真是一个遭罪啊。
这文章就来看一下如何跑mongo的docker镜像,并且可以在局域网访问,内容相对简单,也是记录我的自学过程。
第一步
获得mongo镜像,命令如下,
# 拉取mongo镜像 docker pull mongo # 查看本地库mongo镜像 docker images mongo
第二步
启动mongo镜像,如下
# 启动mongo镜像 docker run -itd -P --name mongo-server mongo bash # 查看mongo进程 docker ps -a
第三步
进入容器并启动mongo,如下
# 进入mongo容器,其中‘mongo-server'是mongo容器别名 docker exec -it mongo-server bash # 启动mongo服务 mongod & # 在容器中查看mongo进程 ps -ef | grep mongo
启动以后会看到如下日志(最后几行),
2017-06-13T07:25:56.318+0000 I FTDC [initandlisten] Initializing full-time diagnostic data capture with directory '/data/db/diagnostic.data' 2017-06-13T07:25:56.328+0000 I INDEX [initandlisten] build index on: admin.system.version properties: { v: 2, key: { version: 1 }, name: "incompatible_with_version_32", ns: "admin.system.version" } 2017-06-13T07:25:56.328+0000 I INDEX [initandlisten] building index using bulk method; build may temporarily use up to 500 megabytes of RAM 2017-06-13T07:25:56.329+0000 I INDEX [initandlisten] build index done. scanned 0 total records. 0 secs 2017-06-13T07:25:56.329+0000 I COMMAND [initandlisten] setting featureCompatibilityVersion to 3.4 2017-06-13T07:25:56.329+0000 I NETWORK [thread1] waiting for connections on port 27017
第四步
本地验证测试,输入mongo启动mongo命令行客户端,如下内容
root@01ff7ed6377c:/# mongo MongoDB shell version v3.4.4 connecting to: mongodb://127.0.0.1:27017 2017-06-13T07:34:00.289+0000 I NETWORK [thread1] connection accepted from 127.0.0.1:55650 #2 (1 connection now open) 2017-06-13T07:34:00.290+0000 I NETWORK [conn2] received client metadata from 127.0.0.1:55650 conn2: { application: { name: "MongoDB Shell" }, driver: { name: "MongoDB Internal Client", version: "3.4.4" }, os: { type: "Linux", name: "PRETTY_NAME="Debian GNU/Linux 8 (jessie)"", architecture: "x86_64", version: "Kernel 3.10.0-327.28.3.el7.x86_64" } }
接着输入测试命令,
> show dbs; admin 0.000GB local 0.000GB >
第五步
在局域网访问docker中的mongo,由于启动的时候是使用的随机端口映射,意思是宿主机产生一个随机端口去映射mongo的27017端口,通过‘docker ps -a'命令查看宿主机随机端口,如下,
docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 01ff7ed6377c mongo "docker-entrypoint.sh" 15 minutes ago Up 15 minutes 0.0.0.0:32773->27017/tcp mongo-server
如上,宿主机随机端口为32773,通过配置robomongo客户端连接mongo,如下,
结果正常。
如果要停止mongo可以使用如下命令,
# 登入mongo mongo # 选择使用admin库,在其他的库不行 use admin # 关闭mongo db.shutdownServer()
通过‘ps -ef | grep momgo'查看mongo进程是否存在,如果不存在说明关闭成功。
总结
以上就是这篇文章的全部内容了,希望本文的内容对给各位iOS开发者们能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍详解在Vue中如何使用axios跨域访问数据,包括了详解在Vue中如何使用axios跨域访问数据的使用技巧和注意事项,需要的朋友参考一下 最近在项目中需要用到axios,所以就恶补一下这个axios到底是什么东东。越来它是vue-resource的替代品,官网也说了,以后都用axios, vue-resource不在维护。那么这个axios怎么用呢,上网搜索了一大堆,基本上都是雷同,
本文向大家介绍在Docker中使用mongodb数据库的实现代码,包括了在Docker中使用mongodb数据库的实现代码的使用技巧和注意事项,需要的朋友参考一下 获取 mongo 镜像 运行 mongodb 服务 运行 mongodb 客户端 使用 mongo-express 管理mongodb mongo-express是MongoDB的一个可视化图形管理工具,这里我们还是通过docker来运
问题内容: 我已经为Java应用程序成功创建了一个小型软件工程环境(SEE),该环境除其他工具外还基于maven和nexus。我的实际问题是-并不是一个真正的惊喜- 链接通常需要访问Internet才能从中央存储库获取请求的工件。但是SEE必须严格离线,并且无法更改它(..出于安全原因)。 我的第一个快速解决方案是镜像连接到Internet的计算机上的nexus / maven安装,运行一些标准p
我如何访问Docker使用RoboMongo或类似工具创建的mongo数据库? 在使用Doncker之前,我已经在Linux机器上安装了mongodb。所以我不能在docker compse中使用端口“27017:27017”。yml。我使用“27018:27018”: 我可以使用RoboMongo查看我在预docker mongo中创建的所有数据库。但是我怎样才能进入码头工人的房间呢? 这是我的
本文向大家介绍Python操作MongoDb数据库流程详解,包括了Python操作MongoDb数据库流程详解的使用技巧和注意事项,需要的朋友参考一下 1.简介 MongoDB是一个基于分布式文件存储的文档数据库,可以说是非关系型(NoSQL,Not Only SQL)数据库中比较像关系型数据库的一个,具有免费、操作简单、面向文档、自动分片、可扩展性强、查询功能强大等特点,对大数据处理支持较好,旨
问题内容: 2 是否可以从2个不同的mongdb数据库服务器中检索数据? 问题答案: 更新资料 现在可以连接到远程/多个数据库: mongodb url 在哪里,例如(带有数据库名称) 目前,这样做有一个缺点:没有Oplog 旧答案 目前这是不可能的。每个流星应用程序都绑定到一个数据库。 有几种方法可以解决此问题,但其价值可能更复杂: 一种选择-使用单独的Meteor应用 在另一个流星应用程序中(