1 NoSQL-Redis概述
NoSQL特点
解耦!
1、方便扩展(数据之间没有关系,很好扩展!)
2、大数据量高性能(Redis一秒写8万次,读取11万,NoSQL的缓存记录级,是一种细粒度的缓存,性能会比较高!)
3、数据类型是多样型的!(不需要事先设计数据库!随取随用!如果是数据量十分大的表,很多人就无法设计了!)
4、传统RDBMS(关系型数据库)和NoSQL
- 传统的RDBMS
- 结构化组织
- SQL
- 数据和关系都存在单独的表中
- 操作语言,数据定义语言
- 严格的一致性
- 基础的事务
- NoSQL
- 不仅仅是数据
- 没有固定的查询语言
- 键值对存储,列存储,文档存储,图形数据库(社交关系)
- 最终一致性,
- CAP定理和BASE(异地多活)
- 高性能,高可用,高可扩展性
关系型和非关系型数据库
一、关系型数据库(SQL Server / MySQL)
关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织。
优点:
1、易于维护:都是使用表结构,格式一致;
2、使用方便:SQL语言通用,可用于复杂查询;
3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。
缺点:
1、读写性能比较差,尤其是海量数据的高效率读写;
2、固定的表结构,灵活度稍欠;
3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。
二、非关系型数据库(Redis / Memechaced / Mongo DB)
非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。
优点:
1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。
2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;
3、高扩展性;
4、成本低:nosql数据库部署简单,基本都是开源软件。
缺点:
1、不提供sql支持,学习和使用成本较高;
2、无事务处理;
3、数据结构相对复杂,复杂查询方面稍欠。
非关系型数据库的分类和比较:
1、文档型
2、key-value型
3、列式数据库
4、图形数据库
NoSQL的四大分类
- K-V键值对︰
- 新浪:Redis
- 美团:Redis + Tair
- 阿里、百度:Redis + memecache
- 文档型数据库( bson格式和json一样)∶
- MongoDB (一般必须要掌握)
- MongoDB是一个基于分布式文件存储的数据库,C++编写,主要用来处理大量的文档!
- MongoDB是一个介于关系型数据库和非关系型数据中中间的产品
- MongoDB是非关系型数据库中功能最丰富,最像关系型数据库的!
- conthDB
- MongoDB (一般必须要掌握)
- 列存储数据库
- HBase
- 分布式文件系统
- 图关系数据库
- 他不是存图形,放的是关系,比如∶朋友圈社交网络,广告推荐!
- Neo4j,InfoGrid ;
Redis入门概述
Redis是什么?
- Redis ( Remote Dictionary Server ),即远程字典服务!
- 是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
- redis会周期性把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
- 免费和开源!是当下最热门的NoSQL技术之一!也被人们称之为结构化数据库!
Redis 能干嘛?
- 1、内存存储、持久化,内存中是断电即失、所以说持久化很重要( rdb、aof )
- 2、效率高,可以用于高速缓存
- 3、发布订阅系统
- 4、地图信息分析
- 5、计时器、计数器(浏览量!)
- 6、…..
特性
- 1、多样的数据类型
- 2、持久化
- 3、集群
- 4、事务