前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >快速搭建属于自己的mongodb数据库

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

作者头像
okaychen
发布2018-01-05 12:19:25
1.3K0
发布2018-01-05 12:19:25
举报
文章被收录于专栏:前端那些事前端那些事

前言

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

参考:心知博客

代码语言:javascript
复制
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,需要进入微软官网下载补丁

代码语言:javascript
复制
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目录,运行下面命令

代码语言:javascript
复制
mongod --dbpath="D:\mongodb\data\db"

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

代码语言:javascript
复制
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服务:

代码语言:javascript
复制
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服务的命令
代码语言:javascript
复制
启动MongoDB:net start MongoDB
停止MongoDB:net stop MongoDB

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

代码语言:javascript
复制
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命令来启动数据库,这样我们就可以通过命令行来执行一些操作了

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

后记

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-08-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 安装
    • 需要注意的是:
      • 1、从mongodb2.2版本开始,mongodb不在支持windowXp
        • 2、如果运行系统为windows server 2008 R2 或者 window 7,需要进入微软官网下载补丁
          • 3、64位的MongoDB将不能在32位的windows上运行启动
          • 配置
            • 1、创建一个用于存放mongodb数据的目录,
              • 2、我把mongo命令添加到path环境变量中,
                • 3、把mongodb设置为windows服务,
                • 后记
                相关产品与服务
                数据库
                云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档