百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

一篇搞定Redis常用命令(redis常用命令总结)

mhr18 2024-10-21 05:42 31 浏览 0 评论

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

前言

上节我们说到Redis的下载和安装,本章说一下Redis的常用命令。基本要求是了解都有哪些命令,不同的数据类型如何存取数据即可。以便后期使用Java语言操作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官网,因不能放置外链,将链接放到评论区,大家可以自行食用,如果不错记得关注,点赞哦!

相关推荐

订单超时自动取消业务的 N 种实现方案,从原理到落地全解析

在分布式系统架构中,订单超时自动取消机制是保障业务一致性的关键组件。某电商平台曾因超时处理机制缺陷导致日均3000+订单库存锁定异常,直接损失超50万元/天。本文将从技术原理、实现细节、...

使用Spring Boot 3开发时,如何选择合适的分布式技术?

作为互联网大厂的后端开发人员,当你满怀期待地用上SpringBoot3,准备在项目中大显身手时,却发现一个棘手的问题摆在面前:面对众多分布式技术,究竟该如何选择,才能让SpringBoot...

数据库内存爆满怎么办?99%的程序员都踩过这个坑!

你的数据库是不是又双叒叕内存爆满了?!服务器监控一片红色警告,老板在群里@所有人,运维同事的电话打爆了手机...这种场景是不是特别熟悉?别慌!作为一个在数据库优化这条路上摸爬滚打了10年的老司机,今天...

springboot利用Redisson 实现缓存与数据库双写不一致问题

使用了Redisson来操作Redis分布式锁,主要功能是从缓存和数据库中获取商品信息,以下是针对并发时更新缓存和数据库带来不一致问题的解决方案1.基于读写锁和删除缓存策略在并发更新场景下,...

外贸独立站数据库炸了?对象缓存让你起死回生

上周黑五,一个客户眼睁睁看着服务器CPU飙到100%——每次页面加载要查87次数据库。这让我想起2024年Pantheon的测试:Redis缓存能把WooCommerce查询速度提升20倍。跨境电商最...

手把手教你在 Spring Boot3 里纯编码实现自定义分布式锁

为什么要自己实现分布式锁?你是不是早就受够了引入各种第三方依赖时的繁琐?尤其是分布式锁这块,每次集成Redisson或者Zookeeper,都得额外维护一堆配置,有时候还会因为版本兼容问题头疼半...

如何设计一个支持百万级实时数据推送的WebSocket集群架构?

面试解答:要设计一个支持百万级实时数据推送的WebSocket集群架构,需从**连接管理、负载均衡、水平扩展、容灾恢复**四个维度切入:连接层设计-**长连接优化**:采用Netty或Und...

Redis数据结构总结——面试最常问到的知识点

Redis作为主流的nosql存储,面试时经常会问到。其主要场景是用作缓存,分布式锁,分布式session,消息队列,发布订阅等等。其存储结构主要有String,List,Set,Hash,Sort...

skynet服务的缺陷 lua死循环

服务端高级架构—云风的skynet这边有一个关于云风skynet的视频推荐给大家观看点击就可以观看了!skynet是一套多人在线游戏的轻量级服务端框架,使用C+Lua开发。skynet的显著优点是,...

七年Java开发的一路辛酸史:分享面试京东、阿里、美团后的心得

前言我觉得有一个能够找一份大厂的offer的想法,这是很正常的,这并不是我们的饭后谈资而是每个技术人的追求。像阿里、腾讯、美团、字节跳动、京东等等的技术氛围与技术规范度还是要明显优于一些创业型公司...

mysql mogodb es redis数据库之间的区别

1.MySQL应用场景概念:关系型数据库,基于关系模型,使用表和行存储数据。优点:支持ACID事务,数据具有很高的一致性和完整性。缺点:垂直扩展能力有限,需要分库分表等方式扩展。对于复杂的查询和大量的...

redis,memcached,nginx网络组件

1.理解阻塞io,非阻塞io,同步io,异步io的区别2.理解BIO和AIO的区别io多路复用只负责io检测,不负责io操作阻塞io中的write,能写多少是多少,只要写成功就返回,譬如准备写500字...

SpringBoot+Vue+Redis实现验证码功能

一个小时只允许发三次验证码。一次验证码有效期二分钟。SpringBoot整合Redis...

AWS MemoryDB 可观测最佳实践

AWSMemoryDB介绍AmazonMemoryDB是一种完全托管的、内存中数据存储服务,专为需要极低延迟和高吞吐量的应用程序而设计。它与Redis和Memcached相似,但具有更...

从0构建大型AI推荐系统:实时化引擎从工具到生态的演进

在AI浪潮席卷各行各业的今天,推荐系统正从幕后走向前台,成为用户体验的核心驱动力。本文将带你深入探索一个大型AI推荐系统从零起步的全过程,揭示实时化引擎如何从单一工具演进为复杂生态的关键路径。无论你是...

取消回复欢迎 发表评论: