Redis简介

redis是一个开源的,高性能数据库,其遵守BSD协议。

Redis 与其他 key - value 缓存产品有以下三个特点:

Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。 Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。 Redis支持数据的备份,即master-slave模式的数据备份。 Redis优势

性能极高– Redis能读的速度是110000次/s,写的速度是81000次/s 。 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。 丰富的特性– Redis还支持 publish/subscribe, 通知, key 过期等等特性。

Redis与其他key-value存储有什么不同

Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。 Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

Redis数据结构及常用操作_常用操作

Redis的5种常用数据结构

1、String (字符串类型)

String类型是Redis中最基本的数据类型,一个key对应一个value。

String类型是二进制安全的,即Redis的String可以包含任何数据。如数字,字符串,jpg图片或者序列化的对象

常用操作:get 、 set 、 del 、 incr、 decr 等

Redis数据结构及常用操作_常用操作_02

2、Hash (哈希)

是一个map - map,指值本身又是一种键值对结构,如 value={{field1,value1},......{fieldN,valueN}}

Redis数据结构及常用操作_数据结构_03

常用操作:命令都是以h开头,如:hget 、hset 、 hdel 等

Redis数据结构及常用操作_数据结构_04

3、List(链表) List 其实就是链表(redis 使用双端链表实现的 List),是有序的,value可以重复,可以通过下标取出对应的value值,左右两边都能进行插入和删除数据。

Redis数据结构及常用操作_常用操作_05

使用列表的技巧

lpush+lpop=Stack(栈) lpush+rpop=Queue(队列) lpush+ltrim=Capped Collection(有限集合) lpush+brpop=Message Queue(消息队列)

Redis数据结构及常用操作_Redis_06

4、Set (集合)

集合类型也是用来保存多个字符串的元素,但和列表不同的是集合中 1. 不允许有重复的元素,2.集合中的元素是无序的,不能通过索引下标获取元素,3.支持集合间的操作,可以取多个集合取交集、并集、差集等

常用操作:命令都是以s开头的,如:sset 、srem、scard、smembers、sismember等

Redis数据结构及常用操作_常用操作_07

5、zset (有序集合)

有序集合和集合有着必然的联系,保留了集合不能有重复成员的特性,区别是,有序集合中的元素是可以排序的,它给每个元素设置一个分数,作为排序的依据。(有序集合中的元素不可以重复,但是score 分数 可以重复)

Redis数据结构及常用操作_常用操作_08

常用操作:命令都是 以 z 开头的,如: zadd 、 zrange、 zscore等

按照下标删除元素:0 -1 删除所有的value