快速搭建属于自己的mongodb数据库

前言

MongoDB 是一个基于分布式文件存储的数据库。由C++语言编写,支持Windows,Linux,OSX,Solaris等平台,默认端口为27017,是一个效率非常高的nosql数据库。

我的测试环境:window10  64位

我的安装路径:D:\mongodb

我学习mongodb的笔记本:MongoDB

配置mongodb我也遇到了两个关键性的问题,记录这篇博客希望搭建mongodb的同行者,可以顺利完成配置。

安装

下载地址:http://www.mongodb.org/downloads

选择下载版本:

我下载的是最新版本的zip格式。

需要注意的是:

1、从mongodb2.2版本开始,mongodb不在支持windowXp

参考:心知博客

PLATFORM SUPPORT
Starting in version 2.2, MongoDB does not support Windows XP. Please use a more recent version of Windows to use more recent releases of MongoDB.

2、如果运行系统为windows server 2008 R2 或者 window 7,需要进入微软官网下载补丁

IMPORTANT
If you are running any edition of Windows Server 2008 R2 or Windows 7, please install a hotfix to resolve an issue with memory mapped files on Windows.

并且这里需要特别注意: 下载完成后会得到一个exe文件,但是这里并不能直接对这个文件进行安装,需要先将其解压,解压后得到 Windows6.1-KB2731284-v3-x64.msu 文件,这时候才可以进行安装,之后重启即可

3、64位的MongoDB将不能在32位的windows上运行启动

配置

1、创建一个用于存放mongodb数据的目录,

这里我创建在D:\mongodb\data\db,打开cmd(这里我用的Git Bash),进入到mongodb的bin目录,运行下面命令

mongod --dbpath="D:\mongodb\data\db"

然后出现了我遇到的第一个问题,

2016-12-29T22:30:02.229+0800 I CONTROL  [initandlisten] MongoDB starting : pid=10220 port=27017 dbpath=C:\Program Files\MongoDB\db 64-bit host=Lenovo
2016-12-29T22:30:02.234+0800 I CONTROL  [initandlisten] targetMinOS: Windows 7/Windows Server 2008 R2
2016-12-29T22:30:02.235+0800 I CONTROL  [initandlisten] db version v3.4.1
2016-12-29T22:30:02.237+0800 I CONTROL  [initandlisten] git version: 5e103c4f5583e2566a45d740225dc250baacfbd7
2016-12-29T22:30:02.238+0800 I CONTROL  [initandlisten] OpenSSL version: OpenSSL 1.0.1t-fips  3 May 2016
2016-12-29T22:30:02.240+0800 I CONTROL  [initandlisten] allocator: tcmalloc
2016-12-29T22:30:02.241+0800 I CONTROL  [initandlisten] modules: none
2016-12-29T22:30:02.241+0800 I CONTROL  [initandlisten] build environment:
2016-12-29T22:30:02.243+0800 I CONTROL  [initandlisten]     distmod: 2008plus-ssl
2016-12-29T22:30:02.244+0800 I CONTROL  [initandlisten]     distarch: x86_64
2016-12-29T22:30:02.245+0800 I CONTROL  [initandlisten]     target_arch: x86_64
2016-12-29T22:30:02.246+0800 I CONTROL  [initandlisten] options: { storage: { dbPath: "C:\Program Files\MongoDB\db" } }
2016-12-29T22:30:02.249+0800 I STORAGE  [initandlisten] exception in initAndListen: 20 Attempted to create a lock file on a read-only directory: C:\Program Files\MongoDB\db, terminating
2016-12-29T22:30:02.251+0800 I NETWORK  [initandlisten] shutdown: going to close listening sockets...
2016-12-29T22:30:02.255+0800 I NETWORK  [initandlisten] shutdown: going to flush diaglog...
2016-12-29T22:30:02.256+0800 I CONTROL  [initandlisten] now exiting
2016-12-29T22:30:02.257+0800 I CONTROL  [initandlisten] shutting down with code:100

最后出现shutting down with code :100,

在心知博客我找到了答案,原因在于:我们进入的命令提示符只是普通模式,所以出现无法创建文件的问题,切换到管理员模式,重新运行命令:

然后就可以正常启动。

2、我把mongo命令添加到path环境变量中,

这样我就不需要每次都进入到mongodb下的bin中执行mongo命令了。

3、把mongodb设置为windows服务,

采用管理员:命令提示符,切换到安装mongodb目录的bin目录,运行下面命令,把MongoDB设置为Windows服务:

mongod --dbpath="D:\mongodb\data\db" --logpath="D:\mongodb\data\log" --logappend --directoryperdb --serviceName "MongoDB" --serviceDisplayName "MongoDB" --install

参数解读:

 --dbpath="D:\mongodb\data\db"   mongodb的数据目录

 --logpath="D:\mongodb\data\log" --logappend   指定日志文件。并且日志是以追加的方式输出的

 --serviceName "MongoDB" --serviceDisplayName "MongoDB"   windows服务器名称和显示名称为MongoDB

 --directoryperdb   表示每个db都会新建一个目录

 --install        进行安装,与之相对的是--remove

启动停止mongodb服务的命令

启动MongoDB:net start MongoDB
停止MongoDB:net stop MongoDB

然后我遇到了第二个问题,服务器安装成功之后,进行启动,发现无法启动,查看log日志文件,有这样的信息:

2016-12-29T23:51:23.705+0800 I CONTROL  [initandlisten] options: { service: true, storage: { dbPath: "D:\mongodb\data\db", directoryPerDB: true }, systemLog: { destination: "file", logAppend: true, path: "D:\mongodb\data\log\mongodb.log" } }
2016-12-29T23:51:23.706+0800 I -        [initandlisten] Detected data files in C:\Program Files\MongoDB\db created by the 'wiredTiger' storage engine, so setting the active storage engine to 'wiredTiger'.
2016-12-29T23:51:23.707+0800 I STORAGE  [initandlisten] exception in initAndListen: 72 Requested option conflicts with current storage engine option for directoryPerDB; you requested true but the current server storage is already set to false and cannot be changed, terminating
2016-12-29T23:51:23.707+0800 I NETWORK  [serviceStopWorker] shutdown: going to close listening sockets...
2016-12-29T23:51:23.707+0800 I NETWORK  [serviceStopWorker] shutdown: going to flush diaglog...
2016-12-29T23:51:23.707+0800 I CONTROL  [serviceStopWorker] now exiting
2016-12-29T23:51:23.707+0800 I CONTROL  [serviceStopWorker] shutting down with code:49

大致意思就是说存储引擎冲突,(之前在命令行启动过mongodb服务,然后就在数据目录生成了数据文件)

这个时候我们可以到数据目录中找到storage.bson这个文件,删除即可。

我们可以通过添加到环境变量中的mongo命令来启动数据库,这样我们就可以通过命令行来执行一些操作了

 到这里我们已经能正常使用mongodb来执行工作了,我遇到的两个问题在心知博客中也找到了答案。

后记

  我的mongodb的笔记本主要是记录mongo文档的学习情况,会不断更新。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Python爬虫与算法进阶

Scrapy源码(1)——爬虫流程概览

前言 使用 Scrapy 已经有一段时间了,觉得自己有必要对源码好好的学习下了,所以写下记录,希望能加深自己的理解。 Scrapy | A Fast and P...

3244
来自专栏杂七杂八

Scrapy爬取数据初识

Scrapy爬取数据初识 初窥Scrapy Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架。 可以应用在包括数据挖掘,信息处理或存储历史数据...

3146
来自专栏python3

Centos7 安装python虚拟环境+Django

鉴于virtualenv不便于对虚拟环境集中管理,所以推荐直接使用virtualenvwrapper。 virtualenvwrapper提供了一系列命令使得和...

1072
来自专栏流柯技术学院

【原创】SQLServer将数据导出为SQL脚本的方法

        最近很多同学问到一个问题,如何将MSSQLServer的数据库以及里面的数据导出为SQL脚本,主要问的是MSSQLServer2000和2005...

943
来自专栏python3

scrapy入门学习(原理)

网络爬虫又称网页蜘蛛,网络机器人,是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本。如果有兴趣可查看百度百科网络爬虫

742
来自专栏Vamei实验室

被解放的姜戈07 马不停蹄

前面的文章研究了Django最主要的几个方面:数据库,模板,动态生成页面等。但都是使用python manage.py runserver来运行服务器。这是一个...

18110
来自专栏coder修行路

一篇文章帮你解决python的包管理

写python代码的人都知道,一个项目写下下来,不可避免的都需要使用很多第三方包,通常我们都是通过pip install ,然而当我们需要上线的时候问题来了,如...

3035
来自专栏魏艾斯博客www.vpsss.net

Windows 服务器远程桌面不能复制粘贴怎么解决

有网友的 Windows 服务器远程桌面不能复制粘贴,具体情况是在远程桌面复制文本,再粘贴是空白的啥都没有了(粘贴选项是灰色的不可选状态),这种情况解决起来也不...

1604
来自专栏乐沙弥的世界

Windows平台下安装MongoDB

wmic os get caption wmic os get osarchitecture

1023
来自专栏编程微刊

vue踩坑-Error: listen EADDRNOTAVAIL 192.168.1.122:8081

每天上班,重启电脑,按照下面的步骤,打开vue的项目,开始编写代码,但是,今天一如往常一般操作: 1:cd /项目名称 下面就是运行项目了,cd /项目名称...

1473

扫码关注云+社区