redis是一个开源免费的高性能的key-value数据库。与普通的key-value缓存产品相比具有以下三个特点:
- 支持数据持久化,redist可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- 提供了多种数据类型,除了key-value,还提供了list,set,zset,hash,geo,hyperloglog,Bitmap等
- 支持数据的备份,即master-slave(主从)模式的数据备份。
redis的优势
- 性能极高-根据官方提供的数据,redis读取的速度最高为110000次/s,写的速度最高可以达到81000次/s.
- redis提供了丰富的数据类型-支持二进制案例的String,List,Hashes,Sets以及OrderedSets数据类型的操作。
- 原子性-redis所有的单条命令都是原子性的,redis事务的原子性具有一定的争议。绝大部分人认为redist事务不具备原子性,因为执行事务时某一条命令的出错并不影响其他命令的执行,即不满足:要么全部执行,要么都不执行。也有少数人认为redis事务具有原子性,在事务命令中故意编写错误的命令(可参照编译时异常理解),执行的时候直接报错,即全部无法执行。
- redis还提供了丰富的特性 – Redis还支持 publish/subscribe(发布/订阅), 通知, key 过期等等特性。
redis与其他key-value存储的区别
-
Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。
-
Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。