分布式数据库系统通常使用较小的计算机系统,每台计算机可单独放在一个地方,每台计算机中都可能有DBMS的一份完整拷贝副本,或者部分拷贝副本,并具有自己局部的数
据库,位于不同地点的许多计算机通过网络互相连接,共同组成一个完整的、全局的逻辑上集中、物理上分布的大型数据库。大数据时代,面对海量数据量的井喷式增长和不断
增长的用户需求,分布式数据库必须具有如下特征,才能应对不断增长的海量数据:
● 高可扩展性:分布式数据库必须具有高可扩展性,能够动态地增添存储节点以实现存储容量的线性扩展。
● 高并发性:分布式数据库必须及时响应大规模用户的读/写请求,能对海量数据进行随机读/写。
● 高可用性:分布式数据库必须提供容错机制,能够实现对数据的冗余备份,保证数据和服务的高度可靠性。
分布式数据库在商业上有广泛的应用,其中MongoDB,Redis , Hbase就是应用很广泛的分布式数据库。
4.1MongoDB的介绍
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系数据库和非关系数据库之
间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点
是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。它的特点是高性
能、易部署、易使用,存储数据非常方便。主要功能特性有:
● 面向集合存储,易存储对象类型的数据。
● 模式自由。
● 支持动态查询。
● 支持完全索引,包含内部对象。
● 支持查询。
● 支持复制和故障恢复。
● 使用高效的二进制数据存储,包括大型对象(如视频等)。
● 自动处理碎片,以支持云计算层次的扩展性
● 支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。
● 文件存储格式为BSON(一种JSON的扩展)
● 可通过网络访问
MongoDB服务端可运行在Linux、Windows或mac os x平台,支持32位和64位应用,默认端口为27017。推荐运行在64位平台,因为MongoDB在32位模式运行时支持的最大文件尺寸为2GB。MongoDB 的基本操作如下:
(1) 打开数据库服务如下
net start MongoDB和net stopMongoDB来启动和停止MongoDB,或者可以在本地服务中操作,如下图
(2) MongoDB基本的增删查改操作
1.显示基本的数据库
>show dbs 默认情况下有2数据库
admin
local
> useadmin 切换到admin数据库
switched to db admin
> showcollections 显示admin数据库下面的集合集
system.indexes
2.新建集合集:
> db.createCollection("myCollection");
{ "ok" : 1 }
> show collections
system.indexes
myCollection
>
3. 插入数据:
> db.myCollection.insert({uid:1,myCollectionname:"Falcon.C",age:25});
> db.myCollection.insert({uid:2,myCollectionname:"aabc",age:24});
4.查询数据:
> db.myCollection.find();
{ "_id" : ObjectId("4b81e74c1f0fd3b9545cba43"),"uid" : 1, "myCollectionname" : "Falcon.C","age" : 25 }
{ "_id" : ObjectId("4b81e74d1f0fd3b9545cba44"),"uid" : 2, "myCollectionname" : "aabc","age" : 24 }
5. 更新数据:
> db.myCollection.update({uid:1},{$set:{age:26}})
6.删除数据
db.myCollection.remove();
db.c1.remove({name:"myCollection1"});//删除特定数据
7. 排序:
db.myCollection.find().sort(age:1); //1是升序 0是降序
8.可视化界面Robomongo
(3) MongoDB的优缺点
1. 优点

本文详细介绍了分布式数据库系统的重要性及其特点,重点关注MongoDB、Hbase和Redis这三种广泛应用的分布式数据库。MongoDB是一个高性能、易部署的文档型数据库,支持动态查询和丰富的索引;Hbase是面向列的开源数据库,适合存储非结构化数据,具有高并发读写能力;Redis则是一个Key-Value存储系统,提供多种数据结构和高读写性能。三者各有优势,如MongoDB的灵活性,Hbase的列存储和Redis的内存操作,但也有各自的局限,如不支持某些事务操作等。
最低0.47元/天 解锁文章
1701

被折叠的 条评论
为什么被折叠?



