NoSQL
NoSQL:一类新出现的数据库
特点:
1.不支持SQL语法
2.存储结构和传统的关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
3.NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的spi和语法,以及擅长的业务场景
NoSQL中的产品种类相当多:
- Mongodb
- Redis
- Hbase hadoop
- Cassandra hadoop
NoSQL和SQL之间的比较
1、sql适用于关系非常复杂的数据查询场景,nosql反之
2、事务特性的支持,sql对事物支持非常完善,而nosql基本不支持
Redis简介
Redis开源的使用C语言编写、支持网络、可基于内存亦可支持持久化的日志型、key-value数据库,并提供多种语言的API。
Redis特性
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list、set(集合)、zset(有序的集合)、hash等数据结构的存储
- Redis支持数据的备份,即master-slave模式的数据备份
Redis优势
- 性能极高-Redis能读的速度是11w次每秒,写的速度是8.1w次每秒
- 丰富的数据类型-Redis支持二进制案例的strings,lists,hashes,sets及ordered sets数据类型操作
- 原子-Redis的所有操作都是原子性的,同事Redis还支持对几个操作全合并后的原子性执行
- 丰富的特性-Redis还支持publish/subscribe,通知,key过期等等特性
Redis应用场景
用来做缓存(ehcache/memcached)–redis的所有数据是放在内存中的(内存数据库)
可以在某些特定应用场景下替代传统数据库–比如社交类应用
在一些大型系统中,巧妙的实现一些特定的功能:session共享、购物车