云计算最近越来越热,各类云计算中心也是遍地开花,而mongodb是非关系数据库(nosql)中比较热门的技术之一,我也有幸在做这方面的工作,平时学习以mongodb官方文档为主(http://dl.mongodb.org/dl/docs/,该文档每天都会生成一个新版本),它里面包含了开发指南和管理指南两大部分的内容。碰到问题都是在mongodb官方论坛:http://groups.google.com/group/mongodb-user 获取帮助。
目前有一本中文书《mongodb权威指南》,里面的内容就是以mongodb官方文档为基础翻译而来,大家可以关注一下。由于mongodb现在的版本已经是2.0.1了,文档的内容也做了一些更新(和《mongodb权威指南》相比更新不会太多),所以萌生了一个翻译目前版本的mongodb官方文档的想法,一来和大家交流学习,二来可以督促自己更深入的学习这个文档。
我使用的文档是在2011年11月22日下载的,虽然每天都在更新,但是变动不大(除非有新的mongodb版本发布)。
翻译的内容分成开发者部分和管理者部分(和官方文档保持一致)。
附上mongodb的简介(来自百度百科):
简介
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
特点
它的特点是高性能、易部署、易使用,存储数据非常方便。
主要功能特性有:
*面向集合存储,易存储对象类型的数据。
*模式自由。
*支持动态查询。
*支持完全索引,包含内部对象。
*支持查询。
*支持复制和故障恢复。
*使用高效的二进制数据存储,包括大型对象(如视频等)。
*自动处理碎片,以支持云计算层次的扩展性。
*支持RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
*文件存储格式为BSON(一种JSON的扩展)。
*可通过网络访问。
使用原理
所谓“面向集合”(Collection-Oriented),意思是数据被分组存储在数据集中,被称为一个集合(Collenction)。每个集合在数据库中都有一个唯一的标识名,并且可以包含无限数目的文档。集合的概念类似关系型数据库(RDBMS)里的表(table),不同的是它不需要定义任何模式(schema)。 模式自由(schema-free),意味着对于存储在mongodb数据库中的文件,我们不需要知道它的任何结构定义。如果需要的话,你完全可以把不同结构的文件存储在同一个数据库里。 存储在集合中的文档,被存储为键-值对的形式。键用于唯一标识一个文档,为字符串类型,而值则可以是各种复杂的文件类型。我们称这种存储形式为BSON(Binary Serialized dOcument Format)。
实际应用
MongoDB服务端可运行在Linux、Windows或OS X平台,支持32位和64位应用,默认端口为27017。推荐运行在64位平台,因为MongoDB在32位模式运行时支持的最大文件尺寸为2GB。