Redis
什么是Redis
为什么要用Nosql
在请求量小的情况下,使用mysql不会有任何问题,但是一旦同时有成千上万个请求同时来访问系统时,就会出现卡顿甚至系统崩溃的情况。最典型的例子就是早期的12306购票网站,一旦到了购票高峰期,12306肯定崩溃。造成这个原因的罪魁祸首就是关系型数据库。
关系型数据库存在两个问题:
- 性能:磁盘IO性能低下
- 扩展性:数据关系复杂,扩展性差,不利于大规模集群
为了解决这两个问题,非关系类型数据库出现了,非关系类型数据库有两个特点:
- 内存存储 :解决磁盘IO性能低的问题
- 不存储关系,只存储数据 : 解决数据关系复杂的问题
NoSQL的常见产品:redis、mongdb
redis介绍
Redis-Remote Dictionary Server。是用C语言开发的一个开源的高性能键值对(key-value)数据库,是一种内存数据库。支持内存运行并支持持久化的NoSQL数据库,有如下几个特征:
- 数据间没有必然的联系
- 内部采用单线程机制工作
- 性能高,支持每秒十几万次的读写操作
- 多数据类型支持:字符串类型(string)、列表类型(list)、散列类型(hash)、集合类型(set)、有序集合类型(sorted_set)
- 持久化支持
redis的应用场合
- 缓存处理
- 任务队列(秒杀,抢购,抢票等)
- 应用排行榜,热点
- 访问统计
- 数据过期处理
- 分布式集群中的session共享
Redis基本操作
数据库的选择
redis中一共有16个数据库,序号0~15,默认数据库为0。可以通过select命令选择数据库
1 | redis-cli |
String类型
添加/修改数据
1 | 127.0.0.1:6379[1]> set user_info zhangshan |
获取数据(若为空,则返回nil)
1 | 127.0.0.1:6379[1]> get user_info |
删除数据(返回1代表成功,0代表失败)
1 | 127.0.0.1:6379[1]> del user_info |
添加/修改多个数据
1 | 127.0.0.1:6379[1]> mset user_name zhangshan user_sex male |
获取多个数据
1 | 127.0.0.1:6379[1]> mget user_name user_sex |
获取字符串长度
1 | 127.0.0.1:6379[1]> STRLEN user_name |
追加信息到原始信息之后
1 | 127.0.0.1:6379[1]> append user_name lisi |
替换指定偏移量后的内容
1 | 127.0.0.1:6379[1]> get user_name |
多操作指令看上去似乎是对单操作指令的简单相加,但其实不然。一条指令执行有三个地方需要耗时:发送指令、处理指令、返回结果。当使用多操作指令的时候,发送和返回都只执行一次,相比较多次只从单操作指令减少了大笔时间。
设置数值增加
1 | 127.0.0.1:6379[1]> INCR user_name |
设置数值减少
1 | 127.0.0.1:6379[1]> DECR user_num |
设置数据具有制定的生命周期(验证码、秒杀、注册等有时间限制的场景)
1 | 127.0.0.1:6379[1]> SETEX user_num 10 99 # 10s后过期 |
查看生命周期剩余时长(大于0表示所剩时长,-1表示永久,-2表示生命周期已结束)
1 | 127.0.0.1:6379[1]> SETEX money 20 100 |
Redis 字符串(String) 命令
命令 | 描述 |
---|---|
Redis Setnx 命令 | 只有在 key 不存在时设置 key 的值。 |
Redis Getrange 命令 | 返回 key 中字符串值的子字符 |
Redis Mset 命令 | 同时设置一个或多个 key-value 对。 |
Redis Setex 命令 | 将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)。 |
Redis SET 命令 | 设置指定 key 的值 |
Redis Get 命令 | 获取指定 key 的值。 |
Redis Getbit 命令 | 对 key 所储存的字符串值,获取指定偏移量上的位(bit)。 |
Redis Setbit 命令 | 对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)。 |
Redis Decr 命令 | 将 key 中储存的数字值减一。 |
Redis Decrby 命令 | key 所储存的值减去给定的减量值(decrement) 。 |
Redis Strlen 命令 | 返回 key 所储存的字符串值的长度。 |
Redis Msetnx 命令 | 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。 |
Redis Incrby 命令 | 将 key 所储存的值加上给定的增量值(increment) 。 |
Redis Incrbyfloat 命令 | 将 key 所储存的值加上给定的浮点增量值(increment) 。 |
Redis Setrange 命令 | 用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始。 |
Redis Psetex 命令 | 这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位。 |
Redis Append 命令 | 如果 key 已经存在并且是一个字符串, APPEND 命令将 value 追加到 key 原来的值的末尾。 |
Redis Getset 命令 | 将给定 key 的值设为 value ,并返回 key 的旧值(old value)。 |
Redis Mget 命令 | 获取所有(一个或多个)给定 key 的值。 |
Redis Incr 命令 | 将 key 中储存的数字值增一。 |
Hash类型
Hash(哈希散列)是 Redis 基本数据类型,值value 中存储的是 hash 表。Hash 特别适合用于存储对象。
添加/修改数据
1 | 127.0.0.1:6379[1]> hset list name zs,li,ww age 18 |
获取数据
1 | 127.0.0.1:6379[1]> HGET list name |
删除数据
1 | 127.0.0.1:6379[1]> HDEL list age |
获取哈希表中字段的数量
1 | 127.0.0.1:6379[1]> HLEN list |
获取哈希表中是否存在指定的字段(0否1是)
1 | 127.0.0.1:6379[1]> HEXISTS list age |
设置指定字段的数值增加
1 | 127.0.0.1:6379[1]> HINCRBY list age 10 |
Redis 哈希(Hash) 命令
命令 | 说明 |
---|---|
HDEL | 用于删除哈希表中一个或多个字段 |
HEXISTS | 用于判断哈希表中字段是否存在 |
HGET | 获取存储在哈希表中指定字段的值 |
HGETALL | 获取在哈希表中指定 key 的所有字段和值 |
HINCRBY | 为存储在 key 中的哈希表指定字段做整数增量运算 |
HKEYS | 获取存储在 key 中的哈希表的所有字段 |
HLEN | 获取存储在 key 中的哈希表的字段数量 |
HSET | 用于设置存储在 key 中的哈希表字段的值 |
HVALS | 用于获取哈希表中的所有值 |
需要注意的是,hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象。每个hash可以存储2^32-1个键值对。
List类型
list类型数据用于存储多个数据,并对数据进入存储空间的顺序进行区分,值value 中存储的是列表。list类型的数据可以保存多个数据,底层使用双向链表存储结构实现。
既然是双向链表的方式实现,那么就可以从左右两边添加和修改数据,在头和尾增和删除数据的效率较高,中间比较低,按照插入顺序进行排序,数据可以重复。应用场景:点赞、最新消息。下面是具体操作:
添加/修改数据
1 | 127.0.0.1:6379[1]> LPUSH list 1 2 3 4 # 将一个或多个值插入到列表头部 |
获取数据
1 | lrange key start stop (stop=-1时表示最后一个元素) |
获取并删除数据
1 | lpop key # 移出并获取列表的第一个元素 |
移除数据指定数据
从列表 key 中删除前 count 个值等于 element
的元素。 这个 count 参数通过下面几种方式影响这个操作:
- count > 0: 从头到尾删除值为 value 的元素。
- count < 0: 从尾到头删除值为 value 的元素。
- count = 0: 移除所有值为 value 的元素。
比如, LREM list -2 “hello” 会从列表key中删除最后两个出现的 “hello”。
1 | 127.0.0.1:6379[1]> LRANGE list 0 -1 |
需要注意的是,不存在key会被当作空list处理,所以当 key 不存在的时候,这个命令会返回 0。
返回值
整数: 删除元素个数。
Redis List 命令
命令 | 描述 |
---|---|
BLPOP | 移出并获取列表的第一个元素 |
BRPOP | 移出并获取列表的最后一个元素 |
BRPOPLPUSH | 从列表中弹出一个值,并将该值插入到另外一个列表中并返回它 |
LINDEX | 通过索引获取列表中的元素 |
LINSERT | 在列表的元素前或者后插入元素 |
LLEN | 获取列表长度 |
LPOP | 移出并获取列表的第一个元素 |
LPUSH | 将一个或多个值插入到列表头部 |
LPUSHX | 将一个值插入到已存在的列表头部 |
LRANGE | 获取列表指定范围内的元素 |
LREM | 移除列表元素 |
LSET | 通过索引设置列表元素的值 |
LTRIM | 对一个列表进行修剪(trim) |
RPOP | 移除并获取列表最后一个元素 |
RPOPLPUSH | 移除列表的最后一个元素,并将该元素添加到另一个列表并返回 |
RPUSH | 在列表中添加一个或多个值 |
RPUSHX | 为已存在的列表添加值 |
Set类型
set类型与hash存储结构完全相同,不同点在于,set仅存储键,不存储值,并且值不允许为空,元素不重复。
set类型可以存储大量数据,在查询方面提供更高的效率。
应用场合:利用唯一性,统计地区新生儿状况,统计驾驶证
添加/修改数据
1 | 127.0.0.1:6379[1]> SADD arr 1 2 3 4 |
获取全部数据
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
删除数据
1 | 127.0.0.1:6379[1]> SREM arr 5 4 |
获取集合的成员数
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
判断集合中是否包含指定数据(0否1是)
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
随机获取集合中指定数量的数据
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
移除并返回集合中的n个随机元素
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
返回给定所有集合的交集
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
返回给定所有集合的差集
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
返回所有给定集合的并集
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
返回给定所有集合的交集、并集、差集并存储在 destination 中
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
将 member 元素从 source 集合移动到 destination 集合
1 | 127.0.0.1:6379[1]> SMEMBERS arr |
Redis Set命令
命令 | 描述 |
---|---|
SADD | 向集合添加一个或多个成员 |
SCARD | 获取集合的成员数 |
SDIFF | 返回给定所有集合的差集 |
SDIFFSTORE | 返回给定所有集合的差集并存储在 destination 中 |
SINTER | 返回给定所有集合的交集 |
SINTERSTORE | 返回给定所有集合的交集并存储在 destination 中 |
SISMEMBER | 判断 member 元素是否是集合 key 的成员 |
SMEMBERS | 返回集合中的所有成员 |
SMOVE | 将 member 元素从 source 集合移动到 destination 集合 |
SPOP | 移除并返回集合中的一个随机元素 |
SRANDMEMBER | 返回集合中一个或多个随机数 |
SREM | 移除集合中一个或多个成员 |
SUNION | 返回所有给定集合的并集 |
SUNIONSTORE | 所有给定集合的并集存储在 destination 集合中 |
SSCAN | 迭代集合中的元素 |
Zset类型
每个元素都会有一个权重值,元素会自动按照权重排序,元素不能重复,但是权重可以重复
应用场合:排行榜
待更新…