分布式系统的应用及其各自的特点

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

分布式数据库系统通常使用较小的计算机系统,每台计算机可单独放在一个地方,每台计算机中都可能有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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值