专业编程基础技术教程

网站首页 > 基础教程 正文

一篇搞定Redis常用命令

ccvgpt 2025-01-04 17:37:32 基础教程 3 ℃

满怀忧思,不如先干再说!

前言

上节我们说到Redis的下载和安装,本章说一下Redis的常用命令。基本要求是了解都有哪些命令,不同的数据类型如何存取数据即可。以便后期使用Java语言操作Redis的时候知道它的实现方式其实就是对命令的封装!!!

一篇搞定Redis常用命令

命令分类

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

通用命令

这里列出我们常用的命令,全部命令请参考redis官网:【平台限制:地址放到评论区】

keys pattern

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

127.0.0.1:6379> keys * 
 1) "k1"

dbsize

说明:计算key的总数

127.0.0.1:6379> dbsize 
(integer) 1

exists key

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

127.0.0.1:6379> exists k1 
(integer) 1 

127.0.0.1:6379> exists k2 
(integer) 0

del key[key...]

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

127.0.0.1:6379> del k1 
(integer) 1

expire key seconds

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

127.0.0.1:6379> expire k4 30 
(integer) 1

pexpire key milliseconds

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

127.0.0.1:6379> pexpire k5 90000 
(integer) 1

ttl key

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

127.0.0.1:6379> ttl k5 
(integer) 87

pttl key

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

127.0.0.1:6379> pttl k1 
(integer) 76151

persist key

说明:移除key的过期时间

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

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实现原理

数据结构和内部编码

Redis中的五种数据结构,每一种都有两种以上的内部实现,多种内部编码实现可以在不同应用场景下发挥各自优势。具体的编码实现后边补充一篇文章单独去说!

redis单线程

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

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

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

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

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

注意

1、一次只执行一条命令

2、拒绝长(慢)命令

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

String

说明

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

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

常用命令

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

说明

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

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

常用命令

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

与String对比

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

使用String类型存储

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

方式一:

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

方式二:

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

Hash存储

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

List

说明

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

常用命令

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

说明

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

常用命令

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)

说明

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

常用命令

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使用场景:排行榜等

更多命令可以到Redis官网,因不能放置外链,将链接放到评论区,大家可以自行食用,如果不错记得关注,点赞哦!

Tags:

最近发表
标签列表