大话NoSql
之前看过一本名叫<<大数据挑战的书>>。里面主要讲了NOSQL的内容,感觉讲得确实不错,今天来又一次温习一下,我们大话NOSQL。说道NOSQL。我们肯定联想到的内容就是BigData大数据了,不错,当今的时代就是大数据的时代了。假设放在前几年。互联网还没有这么发达的情况下,或许谁也不会听过这个名词。
在讲正题的时候。我做了张图来看看一般服务端架构在面对业务发展的须要时候。一般的演变趋势:
所以假设公司的数据量发展到一定规模的话,能够採用NoSql.好了最终引出了NoSql这个今天的主题了。NoSql能够理解为”Not Only Sql”,主要指的是非关系型。分布式,不提供ACID的数据库设计模式,强调的是类似于Map的“键值存储”。和”文档存储“。面对海量数据。NoSql 採用了一种弱类型的数据。採用更加简单的数据模型,一般都是用字符串表示全部的数据类型。可是他可能不会像关系型数据库一样有那么好的强一致性。应该nosql是一种最终一致性。NoSql也避免了很多诸如联表查询等复杂操作,基本就是简单的赋值,取值等,
能够实现比較难高的吞吐量。
如今的数据库系统可谓是五彩缤纷,来张图看看:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvQW5kcm9pZGx1c2hhbmdkZXJlbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
在介绍nosql之前,要知道的一些海量数据的理论性知识。CAP理论,C,(Consistency)强一致性。A(Available)可用性,P(Partition Tolerance)分区容忍性,能够理解为系统在存在网络分区的情况下仍然能够接受请求。
自然这让我们联系到了另一个理论ACID。A(Atomic)原子性。C(Consistent)一致性, I(Isolation)隔离性。 D(Durablitity)持续性。
另一个比較重要的协议2PC两阶段提交协议,很多分布式关系数据库採用此协议来完毕分布式事务。
以下我们来真正了解一下详细的NOSQL。
K-V数据库
首先我们来了解是Redis,Redis是一个开源的,高级key-value的数据库。他的value不仅支持String类型,并且还有list,set等结构,Redis採用的是内存进行数据存储。等数据到达一定规模后,在持久化到文件或磁盘中。
基于Redis的特点,新浪微博採用的就是Redis,对于微博这种结构清晰,数据规模庞大的应用来说。Redis当然最适合只是了。
Column-Oriented列式数据库
说到列式数据库,我们不得不提到他的始祖。Bigtable数据库,在后来衍射出的非常多数据库都能看到他的影子,列式数据库强调的是一种面向列的稀疏存储,另一个列族的概念,跟关系型数据库的单行单列,不一样,比較典型的Hadoop採用的HBase数据库。
文档型数据库
文档型数据,我这里说的有2种,MongoDB,另一个CouchDB,两者有非常多共同点存储的都是JSON类型数据类型。在文档数据库中文档成为了数据存储的一个基本单位,因此,所存储的数据,甚至能够要求是无结构的,文档可长,可短,每个都以类似于”{“”id”: 200, “msg”:”haha”}这种json格式保存在数据库中。我们重点关注一下MongoDB,在MongoDB中存在着类似于SQL查询语句的操作。可是又不是跟SQL语句全然同样,比方db,user,find(),MongoDB支持Map/Reduce模型。CouchDB详细RestFul API。能够实现用Http请求实现操作。
二者数据库都借助了Map/Reduce,技术提高了数据处理的效率,这对于与存储非结构化,和半结构化的数据都有非常大的帮助。
图存数据库
图存数据库我刚刚听说这个名词的时候。也是认为难以理解,官方给出的定义:图存数据库使用基础的数据结构,来存储代表一个图形的数据,可以通过很方便的方式优雅的呈现不论什么类型的数据。
图存数据库如今一般有3类,Neo4j数据库。GraphDB图存数据库。OrientDB,图存数据库的查询会模仿图的遍历实现查找。通过朋友找到朋友的朋友。终于找到目标。
NoSql就是分为上述的4种类型。突然心血来潮。相到一个比較重要的知识点,数据处理。数据处理寻常也总是有人在提起,我就提提。我说的数据处理指的是传统的压缩算法的实现。一般有2种,一个哈弗曼编码,学过计算机的,数据结构都上过的吧,还有一个L.Z算法系列的,如今应该已经非常多版本号了吧,是基于窗体互动的,核心思想就是复用同样的字符串,假设后面的字符串出现了前面反复,用一个标记取代,能够大大节省压缩数量。
好了,花了1000多字,理了理思路。也起到了复习的效果了。
大话NoSql的更多相关文章
- NoSql数据库使用半年后在设计上面的一些心得
NoSql数据库这个概念听闻许久了,也陆续看到很多公司和产品都在使用,优缺点似乎都被分析的清清楚楚.但我心里一直存有一个疑惑,它的出现究竟是为了解决什么问题? 这个疑惑非常大,为此我看了很多分析文章, ...
- 非关系型数据库(NoSql)
最近了解了一点非关系型数据库,刚刚接触,觉得这是一个很好的方向,对于大数据 方面的处理,非关系型数据库能起到至关重要的地位.这里我主要是整理了一些前辈的经验,仅供参考. 关系型数据库的特点 1.关系型 ...
- 关系型数据库与NoSQL数据库
关系型数据库的优缺点 优点: 可以做事务处理,从而保证了数据的一致性: 可以进行JOIN等多表查询: 由于以SQL标准化为前提,数据更新的开销很小(相同的字段基本上都只有一处). 缺点: 大量数据的写 ...
- 几款主流 NoSql 数据库的对比
最近小组准备启动一个 node 开源项目,从前端亲和力.大数据下的IO性能.可扩展性几点入手挑选了 NoSql 数据库,但具体使用哪一款产品还需要做一次选型. 我们最终把选项范围缩窄在 HBase.R ...
- “NOSQL” 杂谈
引言: nosql 的兴起和革命,在我看来已经开始逐渐影响到了传统的sql的地位,但是仅仅是影响而已,取代是不太可能的. 正文: 两年前,一个偶然的机会开始接触到 nosql ( mongodb ). ...
- 大话keepalive
大话keepalive 我们说到keepalive的时候,需要先明确一点,这个keepalive说的是tcp的还是http的. tcp的keepalive是侧重在保持客户端和服务端的连接,一方会不定期 ...
- Squirrel: 通用SQL、NoSQL客户端
安装 配置数据库 配置驱动 配置连接 如果你的工作中,需要使用到多个数据库,又不想在多种客户端之间切换来切换去.那么就需要找一款支持多数据库的客户端工具了.如果你要连接多个关系型数据库,你就可以使用N ...
- NoSQL和MongoDB
NoSQL(NoSQL=Not Only SQL),意即“不仅仅是SQL”.关系数据库关注在关系上,NoSQL关注在存储上. 发展背景 (1)传统关系型数据库遇到了性能瓶颈. 高并发读写(High ...
- NoSQL指南
一.数据库发展 1.早期出现的数据库包括平面文件数据管理系统.分层数据管理系统和网络数据管理系统,分别对应的数据结构是线性表.树和图. 平面文件数据管理系统是使用磁带对数据进行顺序存储的,带来的问题不 ...
随机推荐
- Apache POI组件操作Excel,制作报表(二)
本文接上一篇继续探究POI组件的使用. 现在来看看Excel的基本设置问题,以2007为例,先从工作簿来说,设置列宽,因为生成表格列应该固定,而行是遍历生成的,所以可以在工作簿级别来设置列宽, ...
- The Frog's Games(二分)
The Frog's Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Others) ...
- python 弄github代码库列表
1.底 项目要求,征求github的repo的api,为了能够提取repo对数据进行分析. 研究一天.最终克服该问题,較低下. 由于github的那个显示repo的api,列出了 ...
- 免费自学Cocos2d-x3.0final2014原创视频教程(56集)(适用于Cocos2d-x3.1 Cocos2d-x3.2版本号全)
Cocos2d-x3.0final(适用于Cocos2d-x3.1 Cocos2d-x3.2版本号全) 视频播放地址:http://yun.itxdl.cn/course/62 视频下载地址:http ...
- java判断数据类型两种方式
instanceof String s = ""; System.out.println(s instanceof String); // true simp ...
- [跟我学spring学习笔记][IoC]
IoC基础 什么是IoC Ioc—Inversion of Control,即“控制反转”,不是什么技术,而是一种设计思想. ioc做什么 IoC容器帮对象找相应的依赖对象并注入,而不是由对象主动去找 ...
- [转]CSS vertical-align属性详解 作者:黄映焜
CSS vertical-align属性详解 posted @ 2014-08-26 17:44 黄映焜 前言:关于vertical-align属性. 实践出真知. 垂直居中. 第二种用法. ...
- AngularJs directive 'transclude' option 详解
transclude好像不是一个英语单词,有道词典里没有,百度翻译的意思是嵌入. transclude在angularjs的自定义的derective中是比较常见的一个东西,所有有必要要了解它. 我们 ...
- 如何使用Assetic进行文件管理
安装和配置Assetic 从symfony2.8开始,Assetic就不再被包括在symfony标准版.使用任何Assetic的特性之前需要安装AsseticBundel,在命令行执行下面命令: $ ...
- yii2安装与初始化-Yii2学习笔记(一)
一.安装项目: 使用composer下载安装yii2 advanced安装包: composer create-project yiisoft/yii2-app-advanced advanced(自 ...