日期:2014-05-16  浏览次数:20395 次

mongoDB分布式文件存储的数据库

http://www.mongodb.org

?

http://www.iteye.com/topic/987224? mongoDB性能初测与优化

?

?

 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

?

 它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:   

*面向集合存储,易存储对象类型的数据。   

*模式自由。   

*支持动态查询。   

*支持完全索引,包含内部对象。   

*支持查询。   

*支持复制和故障恢复。   

*使用高效的二进制数据存储,包括大型对象(如视频等)。   *自动处理碎片,以支持云计算层次的扩展性   

*支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。   

*文件存储格式为BSON(一种JSON的扩展)   *可通过网络访问

?

所谓“面向集合”(Collenction-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。

?

?

?

?

===================1 安装配置

?

wget http://fastdl.mongodb.org/linux/mongodb-linux-i686-1.8.1.tgz


直接解压缩到目录/usr/local/webserver 下。
# tar zxvf mongodb-linux-i686-1.8.1.tgz -C /usr/local/webserver/

将目录改名,方便以后使用方便。
?mv mongodb-linux-i686-1.4.2/ mongodb


就是32位操作系统只支持最大2G的文件,如果你的应用中数据量很大,
超过了2G,推荐安装64位的操作系统

?

创建目录保存MongoDB数据的目录。
[root@CentOS_Test_Server bin]# mkdir /data0/mongodb_data


启动MongoDB
cd ./mongodb/bin
# ./mongod --fork --dbpath=/data0/mongodb_data --logpath /data0/mongodb_data/mongodb.log --logappend


ps aux | grep mongo
netstat -antl | grep 27017
同时会自动启动一个端口为28017的服务,此服务用于监控MongoDB的状态
[root@CentOS_Test_Server bin]# netstat -a | grep 28017


curl localhost:28017


http://192.168.93.129:28017/

?

?测试
[root@CentOS_Test_Server bin]# ls
运行MongoDB下面bin目录下的mongo命令,就可以进入MongoDB的shell界面了,
跟MySQL有点类似,输入命令help,其它的看帮助基本上就明白了。

?

?

?

?

============================= 2 未测试:启动MongoDB的Master服务
[root@CentOS_Test_Server bin]# ./mongod --fork --master --dbpath /home/masterdb/ --port 27018 --logpath /home/masterdb/mongodb.log --logappend
all output going to: /home/masterdb/mongodb.log
forked process: 11463
[root@CentOS_Test_Server bin]# ls /home/masterdb/
local.0? local.ns? mongodb.log? mongod.lock

启动MongoDB的Slave服务
[root@CentOS_Test_Server bin]# ./mongod --fork --slave --source localhost:27018 --autoresync --slavedelay 30 --dbpath /home/slavedb/ --port 27019 --logpath /home/slavedb/mongodb.log --logappend
all output going to: /home/slavedb/mongodb.log
forked process: 11848
[root@CentOS_Test_Server bin]# ls /home/slavedb/
local.0? local.ns? mongodb.log? mongod.lock? _tmp

测试主从复制的功能
登录到 MongoDB的Master服务,插入一条数据
[root@CentOS_Test_Server bin]# ./mongo localhost:27018
MongoDB shell version: 1.4.2
url: localhost:27018
connecting to: localhost:27018/test
type "help" for help
> use recommender
switched to db recommender
> db.data.insert({name: "caihuafeng"})
> db.data.find()
{ "_id" : ObjectId("4beedc31e0e4fff2ce0295f6"), "name" : "caihuafeng" }

登录MongoDB的Slave服务,我们发现刚才保存到Master里面的数据已经复制到Slave了,这正是我们要看到的效果。
[root@CentOS_Test_Server bin]# ./mongo localhost:27019
MongoDB shell version: 1.4.2
url: localhost:27019
connecting to: localhost:27019/test
type "help" for help
> use recommender
switched to db recommender
> db.data.find()
{ "_id" : ObjectId("4beedc31e0e4fff2ce0295f6"), "name" : "caihuafeng" }

我们再看一下Slave服务上面产生的同步日志(/home/slavedb/mongodb.log)
Sun May 16 01:39:29 repl: from host:localhost:27018
Sun May 16 01:39:29 resync: dropping database recommender
Sun May 16 01:39:29 resync: cloning database recommender to get an initial copy
Sun May 16 01:39:29 allocating new d