《解锁Redis系列2》常用命令和使用场景

喜欢有帮助记得点赞哦,加关注不迷路

一、命令分类

  1. 通用命令
  2. 字符串类型
  3. 哈希类型
  4. 列表类型
  5. 集合类型
  6. 有序集合类型

二、通用命令

这里列出我们常用的命令,全部命令请参考redis官网:http://www.redis.cn/commands.html#

2.1、keys pattern

说明:遍历出所有的key,*为pattern参数,也就是匹配符,类似于正则表达式,keys命令一般不推荐在生产环境中使用,因为如果我们的key非常多,检索起来就非常慢,这个命令比较重,而且redis是单线程的会阻塞其他的命令,如果我们需要检索key,可以使用scan命令

127.0.0.1:6379> keys *
1) "k1"

2.2、dbsize

说明:计算key的总数

127.0.0.1:6379> dbsize
(integer) 1

2.3、exists key

说明:查看key是否存在,返回值 1存在,0不存在

127.0.0.1:6379> exists k1
(integer) 1
127.0.0.1:6379> exists k2
(integer) 0

2.4、del key[key...]

说明:删除指定的一个key或者一组key,返回值是删除key的个数

127.0.0.1:6379> del k1
(integer) 1

2.5、expire key seconds

说明:设置key的过期时间,单位为秒,返回值1说明设置成功,返回0说明key不存在或设置失败

127.0.0.1:6379> expire k4 30
(integer) 1

2.6、pexpire key milliseconds

说明:以毫秒为单位设置过期时间

127.0.0.1:6379> pexpire k5 90000
(integer) 1

2.7、ttl key

说明:查看key的过期时间,以秒为单位,返回值-1永不过期,-2已过期

127.0.0.1:6379> ttl k5
(integer) 87

2.8、pttl key

说明:查看key的过期时间以毫秒为单位

127.0.0.1:6379> pttl k1
(integer) 76151

2.9、persist key

说明:移除key的过期时间

127.0.0.1:6379> persist k1
(integer) 1
127.0.0.1:6379> ttl k1
(integer) -1

2.10、type key

说明:返回key对应的数据类型,分别为string、list、set、zset、hash五种数据类型,如果key不存在返回none

127.0.0.1:6379> type k1
string
127.0.0.1:6379> type k2
none

三、Redis实现原理

3.1、数据结构和内部编码

我们可以参考这位大佬的博文:https://www.cnblogs.com/yangmingxianshen/p/8054094.html,有详细的数据结构和内部编码实现,我这里只做一下总结,Redis中的五种数据结构,每一种都有两种以上的内部实现,多种内部编码实现可以在不同应用场景下发挥各自优势。

3.2、redis单线程

redis是单线程的,在同一个瞬间只可能执行一条命令

那么为什么redis的单线程会这么快呢?

1、主要原因是redis是纯内存操作,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)速度非常快

2、使用多路I/O复用模型,非阻塞I/O

3、单线程避免线程切换和竞态消耗,单线程指的是网络请求模块使用了一个线程(所以不需考虑并发安全性),即一个线程处理所有网络请求,其他模块仍用了多个线程。

3.3、注意

1、一次只执行一条命令

2、拒绝长(慢)命令

keys、flushall、flushdb、slow lua script等时间复杂度高的

四、String

4.1、说明

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。value可以是简单字符串,也可以是复杂的字符串比如JSON,XML等,也可以是数字(小数、整数),甚至是图片或者序列化后的对象,value是一个安全的二进制数据,string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

String类型的使用场景:用来做缓存、计数器、分布式锁等等。

4.2、常用命令

set key value : 设置 key 对应 string 类型的值, 返回 1 表示成功, 0 失败。(说明,设置key多次会覆盖)
setnx(not exist) key value: 如果 key 不存在进行设置,存在就不需要进行设置了,返回0
set key value [ex seconds/px milliseconds]: 设置值的同时设置过期时间
get key: 获取 key 对应的 string 值,如果 key 不存在返回 nil(在redis中nil代表为空)
getset key value : 先获取 key 的值,再设置 key 的值。
mset key1 value1 … : 一次设置多个 key 的值, 成功返回 1 表示所有的值都设置了,失败返回 0 表示没有任何值被设置。
mget key1 key2 … keyN : 一次获取多个 key 的值
msetnx key1 value1 … : 一次设置多个 key 的值,但是不会覆盖已经存在的 key
incr key: 递增,注意 incr 一个不是 int 的 value 会返回错误,incr 一个不在的 key,则设置 key 值为 1。
decr key : 递减, decr 一个不存在 key,则设置 key 值为-1。
incrby key integer: 对 key 加上指定值 , key 不存在设置 key,并认为原来的 value是 0。
decrby key integer: 对 key 减去指定值。decrby 完全是为了可读性,我们完全可以通过 incrby一个负值来实现同样效果,反之一样。
incrbyfloat key float:增加对应的浮点数,没有减去指定值,我们可以传入负数来实现该功能
append[key]方法: 字符串追加方法
strlen[key]方法: 获取字符串的长度
getrange key startindex endstart 获取指定范围的字符串
setrange key 10 value(10表示从第几位开始替换,后面跟上替换的字符串)

五、Hash

5.1、说明

Hash类型是String类型的field和value的映射表,或者说一个String集合。它特别适合存储对象相比较而言,将一个对象类型存储在Hash类型里要比存储在String类型里占用更少的内存空间并方便存取整个对象

Hash应用场景:用一个对象来存储用户信息,商品信息,订单信息等等。

5.2、常用命令

hset key field value: 设置 hash field 为指定值,如果 key 不存在,则创建
hget key field : 获取指定的 hash field。
hmget key filed1…fieldN : 获取全部指定的 hash filed。
hmset key filed1 value1 … filedN valueN : 同时设置 hash 的多个 field。
hincrby key field integer: 指定步长增加。成功返回 hash filed 变更后的值。
hexists key field : 检测指定 field 是否存在。
hdel key field: 删除指定的 hash field。
hlen key: 返回指定 hash 的 field 数量。
hkeys key: 返回 hash 的所有 field。
hvals key : 返回 hash 的所有 value。
hgetall : 返回 hash 的所有 filed 和 value

5.3、与String对比

存储用户信息使用String和Hash存储有什么区别?

5.3.1、使用String类型存储

用户ID为查找的key,存储的value用户对象包含姓名,年龄,生日等信息,如果用普通的key/value结构来存储,主要有以下2种存储方式:

方式一:

第一种方式将用户ID作为查找key,把其他信息封装成一个对象以序列化的方式存储,这种方式的缺点是,增加了序列化/反序列化的开销,并且在需要修改其中一项信息时,需要把整个对象取回,并且修改操作需要对并发进行保护,引入CAS等复杂问题。

方式二:

第二种方法是这个用户信息对象有多少成员就存成多少个key-value对,用户ID+对应属性的名称作为唯一标识来取得对应属性的值,虽然省去了序列化开销和并发问题,但是用户ID为重复存储,如果存在大量这样的数据,内存浪费还是非常可观的

5.3.2、Hash存储

Redis的Hash实际是内部存储的Value为一个HashMap,并提供了直接存取这个Map成员的接口,Key仍然是用户ID, value是一个Map,这个Map的key是成员的属性名,value是属性值,这样对数据的修改和存取都可以直接通过其内部Map的Key(Redis里称内部Map的key为field), 也就是通过 key(用户ID) + field(属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题,很好的解决了问题。

六、List

6.1、说明

list 列表是简单的字符串列表,按照插入顺序排序,数据可以重复。你可以添加一个元素到列表的头部(左边)或者尾部(右边),既可以作为栈,又可以作为队列

6.2、常用命令

lpush key string: 在 key 对应 list 的头部添加字符串元素,返回 1 表示成功, 0 表示 key 存在且不是 list 类型。
rpush key string: 在 key 对应 list 的尾部添加字符串元素
llen key: 返回 key 对应 list 的长度, 如果 key 不存在返回 0
lrange key start end: 返回指定区间内的元素, 下标从 0 开始, 负值表示从后面计算, -1 表示倒数第一个元素 , key 不存在返回空列表。
ltrim key start end : 截取 list 指定区间内元素,成功返回 OK, key 不存在返回错误。
lset key index value: 设置 list 中指定下标的元素值,成功返回 1, key 或者下标不存在返回错误。
lrem key count value : 从 List 的头部(count 正数)或尾部(count 负数)删除一定数量(count)匹配 value 的元素,返回删除的元素数量。count 为 0 时候删除全部。
lpop key: 从 list 的头部删除并返回删除元素。
rpop key: 从 list 的尾部删除并返回删除元素
rpoplpush source destination: 从source列表中删除最后一个元素,添加到des列表中第一个
lindex key index: 返回名称为key的list中index位置的元素
linsert key BEFORE|AFTER pivot value:把 value 插入存于 key 的列表中在基准值 pivot 的前面或后面

List应用场景:好友列表,粉丝列表,消息队列,最新消息排行等

七、Set

7.1、说明

set是string类型的无序集合。集合是通过hashtable实现的,概念和数学中集合基本类似,可以交集,并集,差集等等,set中的元素是没有顺序并且不可重复。所以添加,删除,查找的复杂度都是O(1)

7.2、常用命令

sadd key member: 添加一个 string 元素到 key 对应 set 集合中,成功返回 1,如果元素以及在集合中则返回 0, key 对应的 set 不存在则返回错误。
srem key member: 从 key 对应 set 中移除指定元素,返回删除个数,集合中不存在或者key不存在返回 0,如果 key 对应的不是 set 类型的值返回错误。
spop key [count]: 删除并返回 key 对应 set 中随机的一个元素,如果 set 是空或者 key 不存在返回nil。
srandmember key [count]: 随机取 set 中的一个元素,但是不删除元素。
smove srckey dstkey member: 从 srckey 对应 set 中移除 member 并添加到 dstkey 对应 set 中,整个操作是原子的。 成功返回 1,如果 member 在 srckey 中不存在返回 0, 如果 key 不是 set类型返回错误。相当于剪切复制
scard key: 返回 set 的元素个数,如果 set 是空或者 key 不存在返回 0。
sismember key member: 判断 member 是否在 set 中,存在返回 1, 0 表示不存在或者 key 不存在。
sinter key1 key2 …… keyN : 返回所有给定 key 的交集。
sinterstore dstkey key1 … keyN : 返回所有给定 key 的交集, 并保存交集存到 dstkey 下。
sunion key1 key2 … keyN: 返回所有给定 key 的并集。
sunionstore dstkey key1 … keyN: 返回所有给定 key 的并集, 并保存并集到 dstkey
sdiff key1 key2 … keyN: 返回所有给定 key 的差集。
sdiffstore dstkey key1 … keyN: 返回所有给定 key 的差集,并保存差集到 dstkey
smembers key: 返回 key 对应 set 的所有元素,结果是无序的,如果集合中数据很多,不建议使用
scan key:扫描数据

Set应用场景:共同关注、共同喜好、二度好友、分类标签等功能

八、sorted set(Zset)

8.1、说明

sorted set 是有序集合, 它在 set 的基础上增加了一个顺序属性(score),这一属性在添加,修改元素的时候可以指定, 每次指定后, 会自动重新按新的值调整顺序。 可以理解了有两列的mysql 表,一列存 value,一列存score

8.2、常用命令

zadd key score member: 添加元素到集合,元素在集合中存在则更新对应 score。
zrem key member: 删除指定元素, 1 表示成功,如果元素不存在返回 0。
zincrby key incr member : 增加对应 member 的 score 值, 然后移动元素并保持 skip list 保持有
序。返回更新后的 score 值。
zrank key member : 返回指定元素在集合中的排名(下标), 集合中元素是按 score 从小到大排序的。
zrevrank key member : 同上,但是集合中元素是按 score 从大到小排序。
zrange key start end : 类似 lrange 操作从集合中去指定区间的元素。返回的是有序结果
zrevrange key start end: 同上,返回结果是按 score 逆序的。
zrangebyscore key min max: 返回集合中 score 在给定区间的元素。
zcount key min max: 返回集合中 score 在给定区间的数量。
zcard key: 返回集合中元素个数。
zscore key element: 返回给定元素对应的 score

sorted set使用场景:排行榜等

 

写在最后:

各位的支持和认可(点赞)是我最大的动力,请不要轻轻的来,用力留下你的足迹!

本篇文章有任何错误希望不吝指出,不胜感激!我们下篇再见!

求知并无捷径,如果有,那就是放弃这个幼稚的想法,静下心来多读书、总结

发布了23 篇原创文章 · 获赞 49 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_36386908/article/details/102995951