Visual Studio 2010下编译调试MongoDB源码

考虑到MongoDB使用了boost库源码,参考MongoDB官方文档后,下载编译boost版本是1.42(时间为2010-2-2)或更新版本:

boost版本1.42:

http://sourceforge.net/projects/boost/files/boost/1.42.0/boost_1_42_0.zip/download     

下载boost源码之后,我把boost解压在D盘。

1.在D:\boost_1_42_0\下找到该批处理文件bootstrap.bat,以vs2010命令行方式运行它,并最终生成bjam.exe可执行文件(详细结果及错误信息见生成的bjam.log日志)。    

2.将生成的bjam.exe文件拷贝到“D:\boost_1_42_0”目录下,运行下面命令行:

  1. bjam stage variant=debug  --stagedir="d:\boost_1_42_0" 
  2. --with-filesystem --with-thread --with-date_time --with-program_options 
  3. --layout=versioned threading=multi toolset=msvc-10.0 

如下图:

注:i.如果要生成release链接库文件,需将上面的variant设置成release,形如:

 

  1. bjam stage variant=release .....      

ii.如果要全部生成使用下面编译选项

 

  1. bjam ......  --build-type=complete  

编译过程可能会用一些时间,最终会在”D:\boost_1_42_0″ 生成一个lib目录,里面包括刚生成的库文件。

3.下载已用vs2010编译的SpiderMonkey库文件及源码包,并将其解压到D盘下,下载链接:https://github.com/dwight/vc2010_js

将该文件夹名称改为“js”(因为MongoDB项目会默认指定该路径寻找可用的lib及c源文件),如下图:

说明:SpiderMonkey是由C语言操作的JavaScript引擎,它支持JS1.4和ECMAScript-262规范。该引擎分析、编译和执行脚本,根据JS数据类型和对象的需要进行内存分配及释放操作。目前它是Mozilla项目的一部分。可通过下面链接了解更多信息:

https://developer.mozilla.org/en/SpiderMonkey

源码下载链接:

https://developer.mozilla.org/En/SpiderMonkey/Getting_SpiderMonkey_source_code

另外如何使用spidermonkey参见:

http://www.ibm.com/developerworks/cn/linux/shell/js/js_engine/

4.接下来下载并解压mongod源码包(本人下载的是其最新版本:r1.8.0-rc1),这里我将其也解压在了D盘:

MongoDB-src-r1.8.0-rc1:

https://github.com/MongoDB/mongo/zipball/r1.8.0-rc1 

之后利用vs2010打开 D:\MongoDB-mongo-4d2aeb6\db目录下的解决方案文件“db_10.sln”, 加载之后的视图如下:

在其中的MongoDB项目上,点击鼠标右键,打开”属性”对话框, 在“配置属性”-“c++目录”-“包含目录”中点“编辑”:

    添加对上面的boost源码文件路径的包含:

     

     设置库文件目录选项中添加对刚编译的boost库的路径”D:\boost_1_42_0\lib”声明,如下图:    

   

   

在C/C++常规–“附加包含目录”,中添加”D:\boost_1_42_0″声明,如下图:

5.因为我的机器是32位系统,而下载的MongoDB项目设置为64位,所以要修改一下编译方式,如下图:

    

 一切就绪后,开始编译,时间比较长,耐心等待…    

注:如出现“pch.h文件无法打开”的错误信息时,只要在VS2010中的开该文件即可。

6.如果要调试的话,打开“项目属性”–“配置属性”–“调试”–“命令参数”,输入如下参数  :

 

  1. "--dbpath d:\MongoDB\db" "--port 27017" 

 然后找出db.cpp文件,将断点放在如下函数的第一行代码处:   int main(int argc, char* argv[])

     如下图:

需要说明的是,我一开始使用的是VS2008,但MongoDB源码在最新版本中好像就不再提供vs2008的项目文件了,另外我使用vs2008也一直没有成功编译过MongoDB,不是缺文件就是链接库编译时有问题(google一下,发现国外同行也被类似问题困扰)。所以大家也就不要再VS2008编译上浪费时间了。

好了,到这里主要的内容介绍完了,大家可以通过调试来分析观察MongoDB代码的执行流程了。

参考链接:

http://www.cnblogs.com/wondering/archive/2009/05/21/boost_setup.html

http://www.cnblogs.com/xdotnet/archive/2008/03/22/boost_install_config.html

http://www.MongoDB.org/display/DOCS/Building+with+Visual+Studio+2010  

原文链接: http://www.cnblogs.com/daizhj/archive/2011/03/07/1973764.html   

【编辑推荐】

    1. Visual Studio 2010扩展让JS与CSS实现折叠
    2. 初步了解Visual Studio 2010 Professional专业版
    3. Visual Studio 2010中使用MTLM管理测试工具
    4. Visual Studio 2010 SP1公测版已经发布
    5. Visual Studio 2010中敏捷开发流程模板的应用

 

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/231332.html<

(0)
管理的头像管理
上一篇2025-04-19 15:50
下一篇 2025-04-19 15:52

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注