`
zhengdl126
  • 浏览: 2513080 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

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 datafile /home/slavedb/recommender.ns, filling with zeroes...
Sun May 16 01:39:29 done allocating datafile /home/slavedb/recommender.ns, size: 16MB, took 0.451 secs
Sun May 16 01:39:29 allocating new datafile /home/slavedb/recommender.0, filling with zeroes...
Sun May 16 01:39:31 done allocating datafile /home/slavedb/recommender.0, size: 64MB, took 1.397 secs
Sun May 16 01:39:31 allocating new datafile /home/slavedb/recommender.1, filling with zeroes...
Sun May 16 01:39:31 building new index on { _id: 1 } for recommender.data
Sun May 16 01:39:31 Buildindex recommender.data idxNo:0 { name: "_id_", ns: "recommender.data", key: { _id: 1 } }
...

为了让MongoDB的主从服务可以自动启动,可以把下面的两条命令加到/etc/rc.local中。
/usr/local/webserver/mongodb/bin/mongod --fork --master --dbpath /home/masterdb/ --port 27018 --logpath /home/masterdb/mongodb.log --logappend

/usr/local/webserver/mongodb/bin/mongod --fork --slave --source localhost:27018 --autoresync --slavedelay 30 --dbpath /home/slavedb/ --port 27019 --logpath /home/slavedb/mongodb.log --logappend

 

 

 

 

 

============================= 3 mongodb+php

 

http://us.php.net/manual/en/book.mongo.php
http://www.xiaocai.name/emlog/post/38

 

下载 mongodb_demo.rar

 

 

==================CentOS下安装PHP的mongo扩展
在此页面中
http://www.mongodb.org/display/DOCS/Downloads
可以找到php的MongoDB扩
展的主页面地址
http://pecl.php.net/package/mongo

#wget http://pecl.php.net/get/mongo-1.1.4.tgz
#tar zxvf mongo-1.1.4.tgz
#cd mongo-1.1.4
# /usr/local/webserver/php/bin/phpize
#./configure  --with-php-config=/usr/local/webserver/php/bin/php-config
#make && make install


/usr/local/webserver/php/lib/php/extensions/no-debug-non-zts-20060613/mongo.so


编辑php的配置文件,在里面加入一行extension = "mongo.so"
[root@CentOS_Test_Server mongo-1.0.7]# vim /usr/local/webserver/php/etc/php.ini

我们看到mongo模块已经生效了。
[root@CentOS_Test_Server mongo-1.0.7]# /usr/local/webserver/php/bin/php -m | grep mongo
mongo

 

-----php测试

<?
$connection = new Mongo();
$connection= new Mongo("192.168.93.129");

$db = $connection->selectDB('dbname');
$collection = $db->selectCollection('people');

$person = array(
 'name' => 'Cesar Rodas',
 'email' => 'crodas@php.net',
 'address' => array(
  array(
   'country' => 'PY',
   'zip' => '2160',
   'address1' => 'foo bar'
  ),
  array(
   'country' => 'PY',
   'zip' => '2161',
   'address1' => 'foo bar bar foo'
  ),
 ),
 'sessions' => 0,
);


$safe_insert = true;
$collection->insert($person, $safe_insert);
$person_identifier = $person['_id'];
// ²é¸ղű£´æʾÝ$obj = $collection->findOne();
print_r($obj);
// ²éεµÖµļǼÊ
$cursor = $collection->find();
foreach ($cursor as $id => $value) {
    echo "$id: ";
    print_r($value);
}


?>

 

 

 

 

============================= 4 管理工具

http://blog.imtopone.com/php-mongodb-tools/

 


----------- 1 Mongodb web工具rock_mongo
他区分Windows 与Linux的客户端,windows 还自带nginx客户端,没有PHP环境也可以玩。。

 

http://code.google.com/p/rock-php/wiki/rock_mongo

 

上传至web访问
http://192.168.93.129/rockmongo/src
admin
admin


----------- 2 Try MongoDB
http://try.mongodb.org/
不用安装就可以试用MongoDB? 当然没问题,和tryredis一样,是一个基于web的shell模拟工具,可以让你在不用安装MongoDB的情况下试用MongoDB的各种功能.Just Try It!


----------- 3 Mongo3 – MongoDB 集群管理工具http://github.com/derailed/mongo3

这玩意实在是太炫了!


----------- 4 futon4mongo
http://github.com/sbellity/futon4mongo
这个比较囧一点,貌似是把CouchDB的RESTFul API搬移到MongoDB上实现的,具体未知,而且官方页面上明确告知这是一个实验型产品,不要用在商业项目中.


----------- 5 phpMoAdmin
http://www.phpmoadmin.com/
好吧,你没有看错,我也没有写错.这是一个基于php的MongoDB管理工具,是否能有phpMyAdmin基于MySQL的角色重要就不清楚了.而且居然还支持界面主题订制,我当时就orz了..


----------- 6 MongoVUE
http://blog.mongovue.com/
一个windows下的客户端管理工具,对于未来的功能有一个长长的roadmap。

----------- 7 Server Density
http://www.serverdensity.com/
Server Density 是一个商业的监控服务提供商,其原理是在你要监控的机器上部署其监控代码,运行监控daemon,然后监控数据会传回SD的服务器,SD将数据进行整合,并提供多种平台上的数据查看及故障提醒功能。

 

分享到:
评论

相关推荐

    MongoDB构建分布式文件存储的数据库

    MongoDB构建分布式文件存储的数据库MongoDB构建分布式文件存储的

    MongoDB(分布式文件存储的数据库)

    MongoDB是一个基于分布式文件存储 [1] 的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像...

    分布式文档存储数据库mongodb1

    分布式文档存储数据库mongodb1

    基于分布式文件存储的数据库:MongoDB-win32-x86_64

    MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。 在高负载的情况下,添加更多的节点,可以保证服务器性能。 MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。

    分布式存储数据库MongoDB教程

    分布式存储数据库MongoDB教程

    MongoDB 是一个基于分布式文件存储的数据库.pdf

    MongoDB 是一个面向文档的数据库,其数据存储在类似 JSON 的 BSON(Binary JSON)格式中。MongoDB 的主要特点是其灵活的文档模型,它允许在单个文档中存储结构化、半结构化和非结构化的数据。这使得 MongoDB 成为 ...

    分布式与云计算大作业.pdf

    分布式与云计算大作业 1)、底层为 HDFS 存储,数据存储在 HBase分 布式数据库中,完成数据库和表的设计与创建。 2)实现对数据的添加、查询等基本的数据库操作。 3)使用 MapReduce 编程模型实现问题的计算和...

    MongoDB plog-uniapp数据库设计实战.zip

    mongoDB是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。它介于关系数据库和非关系数据库之间,被认为是非关系数据库当中功能最丰富,最像关系数据库的...

    使用mongodb+koa模拟数据库请求.zip

    mongoDB是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。它介于关系数据库和非关系数据库之间,被认为是非关系数据库当中功能最丰富,最像关系数据库的...

    中文版MongoDB权威指南

    MongoDB分布式文档存储数据库的使用说明及举例

    华南理工大学分布式第4章作业

    自己做的,仅供参考 2.进程1向进程2顺序发送三条信息…… 4.写一段可出现在某main方法中的Java程序片段,用于打开一个最多接受100个字节数据的数据包socket,设置超时周期为5秒…… ……

    分布式文档存储数据库之MongoDB访问控制的操作方法

    上一篇博客主要聊了下分布式文档存储数据库之MongoDB备份与恢复,回顾请参考https://www.jb51.net/article/199845.htm;今天我们来了解下mongodb的访问控制;  什么是访问控制?  简单讲访问控制就是指,哪些用户...

    分布式文档存储数据库之MongoDB备份与恢复的实践详解

    前文我们聊了下分布式文档存储数据库之MongoDB访问控制,回顾请参考https://www.jb51.net/article/199848.htm;今天我们来了解下mongodb的备份与恢复  为什么要备份?  备份的目的是对数据做冗余的一种方式,它...

    mongodb 4.0镜像

    开源的分布式文件存储数据库mongodb 4.0镜像

    数据库笔记,包括mysql,mongodb,redis数据库.zip

    mongoDB是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。它介于关系数据库和非关系数据库之间,被认为是非关系数据库当中功能最丰富,最像关系数据库的...

    最通俗易懂的 MongoDB 非结构化文档存储数据库教程.zip

    mongoDB是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。它介于关系数据库和非关系数据库之间,被认为是非关系数据库当中功能最丰富,最像关系数据库的...

    mongodb-win32-i386-1.2.1

    MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 它的特点是高性能、易部署、易使用,存储数据非常方便。 主要功能特性有: 面向集合存储,易存储...

    数据库管理 技术关键词: MongoDB 内容关键词: NoSQL文档数据库 用途: 用于存储和检索大量的分布式数据

    数据库管理 技术关键词: MongoDB ...内容描述: 一个基于分布式文件存储的开源数据库系统。MongoDB是一个NoSQL数据库,使用文档来存储数据,非常适合处理大量的数据,以及在水平扩展方面具有优势。

    SpringBoot整合MongoDB实现对数据库的CRUD小demo.zip

    mongoDB是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。它介于关系数据库和非关系数据库之间,被认为是非关系数据库当中功能最丰富,最像关系数据库的...

Global site tag (gtag.js) - Google Analytics