一、NoSQL的介绍
NoSQL:一类新出现的数据库( not only sql),它的特点:
- 不持SQL语法
- 存储结构跟传统关系型数据库中的关系表完全不同,NoSQL中存储的数据都是K-V形式
- NoSQL的世界中没有一种通用的语言,每种NoSQL数据库都有自己的api和语法,以及擅长的业务场景
- NoSQL的产品种类相当多:
- Mongodb
- Redis
- Hbase hadoop
- Cassandra hadoop
NoSQL和SQL数据库的比较:
- 适用场景不同:sql数据库适用于关系特别复杂的数据查询场景,nosql反之
- 事务特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
- 两者在不断地取长补短,呈现融合趋势
二、Redis的介绍
1、Redis简介
- Redis是一个开源的使用ANSI C语言编写、支持网络、单线程、可基于内存亦可持久化的日志、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由Vmware主持。从2013年5月开始,Redis的开发由 Pivotal赞助。
- Redis是NoSQL技术营中的一员,它通过多种键值数据型来适应不同场景下的存储需求,借助一些高层级的接口便用其可以胜任,如缓存、队列系统的不同角色。
2、Redis特性
- Redis与其他key - value缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用
- Redis不仅仅支持简单的 key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储
- Redis支持数据的备份,即master-slave模式的数据备份
3、Redis优势
- 性能极高 - Redis读的速度是110000次/s,写的速度是81000次/s。
- 丰富的数据型 - Redis支持二进制案例的 String,List,Hash,Set及ZSet数据类型操作。
- 原子 - Redis的所有操作都是原子性的,同时Redis还支持几个操作合并后的原子性执行(原子性是不支持多线程多进程的)。
- 丰富的特性 - Redis还支持 publish/subscibe,通知,key过期等等特性。
四、Redis应用场景
- 用来做缓存(ehcache/memcached) - redis的所有数据都是放在内存中的(内存数据库)
- 可以在某些特定应用场景下替代传统数据库 - 比如社交类的应用
- 在一些大型系统中,巧妙地实现一些特定的功能:session共享,购物车
- 只要你有丰富的思象力,redis可以给你无限的惊喜......