最近为了解决IM消息记录的高速度写入、多文档类型支持的需求,决定使用MongoDB来解决。

考虑到MongoDB对VS版本要求较高,与我现有的VS版本不兼容,在leveldb、ssdb、redis、hbase等NoSQL中转了一圈,最后还是选择了MongoDB,应了那句话:没有最好的,只有最合适的。

MongoDB由于使用了C++的新特性,官方建议使用VS2013来编译,最低要求VS2010。

MongoDB C++驱动编译过程较为复杂,官方也没有提供编译好的驱动包,网上的资料编译版本都比较老了,特此整理最新的MongoDB C++驱动编译方法。

使用VS2010编译MongoDB C++驱动详解:

1、下载python 2.7.9安装程序(不要使用3.X的版本), 使用32位,因为scons只有32位安装包可用;

下载地址:https://www.python.org/downloads/ 选择:Windows x86 MSI installer

2、下载scons 2.3.4,MongoDB的驱动是用scons构建的,安装后会自动安装到python的脚本目录里;

下载地址:http://www.scons.org/

3、其他教程里有写Python27\Scripts写入PATH这一步,python 2.7.9应该会自动写入,可省略;

4、MongoDB C++驱动依赖Boost库(1.49及以上版本),可以直接下载编译好的Boost文件直接安装,省去了自己编译,节约半天时间;

下载地址:http://sourceforge.net/projects/boost/files/boost-binaries/ 选择:boost_1_57_0-msvc-10.0-32

注意32位和64位区别,需编译64位驱动的下载64位的Boost库。

5、下载MongoDB C++驱动源代码,选择;

下载地址:https://github.com/mongodb/mongo-cxx-driver/wiki/Download%20and%20Compile

推荐下载26compat稳定版分支,解压到本地。

6、命令行下cd进驱动目录,使用以下命令编译;

D:\mongo-cxx-driver-26compat>scons --dbg=on --32 --dynamic-windows --sharedclien
t --cpppath=D:\boost_1_57_0 --libpath=D:\boost_1_57_0\lib32-msvc-10.0 --use-syst
em-boost

这里编译的是32位动态库,编译成功后会生出mongoclient.dll。

cpppath指定boost头文件目录;

libpath指定boost库目录;

其他命令可以参考官网:https://github.com/mongodb/mongo-cxx-driver/wiki/Download%20and%20Compile

编译MongoDB C++驱动遇到的问题:

1、官网推荐编译时使用install选项,按说明的意思是编译后将驱动和头文件安装到指定目录,不过使用时会报boost库找不到的错误;

2、使用编译好的驱动时提示error_codes.h和error_codes.cpp文件找不到,这两个文件在MongoDB C++驱动源码下,拷贝过去即可。

以上是编译MongoDB C++驱动快速的方法,大家在编译时可以参照。

今天听说MongoDB 3.0即将推出,写入速度在原有基础上提升6-7倍,性能很强悍~


记录,为更好的自己!

使用VS2010编译MongoDB C++驱动详解的更多相关文章

  1. libCURL开源库在VS2010环境下编译安装,配置详解

    libCURL开源库在VS2010环境下编译安装,配置详解 转自:http://my.oschina.net/u/1420791/blog/198247 http://blog.csdn.net/su ...

  2. 25.Linux-Nor Flash驱动(详解)

    1.nor硬件介绍: 从原理图中我们能看到NOR FLASH有地址线,有数据线,它和我们的SDRAM接口相似,能直接读取数据,但是不能像SDRAM直接写入数据,需要有命令才行 1.1其中我们2440的 ...

  3. 16.Linux-LCD驱动(详解)

    在上一节LCD层次分析中,得出写个LCD驱动入口函数,需要以下4步: 1) 分配一个fb_info结构体: framebuffer_alloc(); 2) 设置fb_info 3) 设置硬件相关的操作 ...

  4. 16.Linux-LCD驱动(详解)【转】

    转自:https://www.cnblogs.com/lifexy/p/7604011.html 在上一节LCD层次分析中,得出写个LCD驱动入口函数,需要以下4步: 1) 分配一个fb_info结构 ...

  5. linux usb 驱动详解

    linux usb 驱动详解 USB 设备驱动代码通过urb和所有的 USB 设备通讯.urb用 struct urb 结构描述(include/linux/usb.h ). urb 以一种异步的方式 ...

  6. gcc与g++的编译链接的示例详解

    一.编译方式的示例详解 1. 编译C代码 代码如下:main.c /*!  ************************************************************** ...

  7. 18.Llinux-触摸屏驱动(详解)

    本节的触摸屏驱动也是使用之前的输入子系统 1.先来回忆之前第12节分析的输入子系统 其中输入子系统层次如下图所示, 其中事件处理层的函数都是通过input_register_handler()函数注册 ...

  8. 21.Linux-写USB键盘驱动(详解)

    本节目的: 根据上节写的USB鼠标驱动,来依葫芦画瓢写出键盘驱动 1.首先我们通过上节的代码中修改,来打印下键盘驱动的数据到底是怎样的 先来回忆下,我们之前写的鼠标驱动的id_table是这样: 所以 ...

  9. 18.Llinux-触摸屏驱动(详解)【转】

    转自:https://www.cnblogs.com/lifexy/p/7628889.html 本节的触摸屏驱动也是使用之前的输入子系统 1.先来回忆之前第12节分析的输入子系统 其中输入子系统层次 ...

随机推荐

  1. [Install] TeamViewer

    安装TeamViwer 1. $ sudo apt-get -f install 2. 使用gdebi安装TeamViwer. 所以先安装gdebi package. $ sudo apt-get i ...

  2. 基于spring-boot、spring-cloud的websocket服务器多点负载均衡改造

    背景 为应对更多用户使用socket的场景,准备对存放websocket的服务器进行多点搭建并配置负载均衡. 问题 服务器上了多点负载均衡以后,基于socket的部分功能发生了有规律的失效,查看后台日 ...

  3. zookeeper:一.zookeeper集群安装

    1.zookeeper简介2.安装zookeeper2.1 安装环境准备2.2 安装zookeeper2.2.1.解压zookeeper压缩包到/opt/zookeeper2.2.2.编辑zookee ...

  4. 动态内存&对象

    一.对象的生存期 对于 static 对象和自动对象,它们都有着严格定义的生存期. 全局对象:在程序启动时分配,在程序结束时销毁. 局部自动对象:在对象定义语句时分配,在离开块时销毁 局部 stati ...

  5. Thunder团队第三周 - Scrum会议5

    Scrum会议5 小组名称:Thunder 项目名称:i阅app Scrum Master:苗威 工作照片: 参会成员: 王航:http://www.cnblogs.com/wangh013/ 李传康 ...

  6. Alpha 冲刺4

    队名:日不落战队 安琪(队长) 今天完成的任务 组织第四次站立式会议. 完成40%草稿箱前端界面. 明天的计划 剩下的60%草稿箱前端界面. 如果还有时间,尝试去调用数据. 还剩下的任务 回收站前端界 ...

  7. vue服务端渲染axios预取数据

    首先是要参考vue服务端渲染教程:https://ssr.vuejs.org/zh/data.html. 本文主要代码均参考教程得来.基本原理如下,拷贝的原文教程. 为了解决这个问题,获取的数据需要位 ...

  8. adb shell input keyevent值所对应的字符

    转自:http://blog.csdn.net/chen825919148/article/details/18732041 0 -->  "KEYCODE_UNKNOWN" ...

  9. matlab中滤波函数

    matlab自带滤波器函数小结(图像处理)   1 线性平滑滤波器 用MATLAB实现领域平均法抑制噪声程序: I=imread(' c4.jpg '); subplot(231) imshow(I) ...

  10. mysql(一) 关联查询的方式

    mysql做关联查询时,一般使用join....on.....的语法. 但还有其它两种语法形式,三者的主要区别在于书写形式,其余方面并无太多差异. 如下三种形式: select * from trad ...