Redis常用操作命令整理
mhr18 2024-11-28 08:34 10 浏览 0 评论
Redis(Remote Dictionary Server)是一个开源的内存数据结构存储系统,常被用作数据库、缓存和消息队列等。它支持多种数据结构,包括字符串、哈希表、列表、集合和有序集合。以下是 Redis 的一些常见操作:
连接 Redis
可以使用 redis-cli 命令连接到 Redis 服务器。例如:
redis-cli -h host -p port -a password
其中 host 是 Redis 服务器的主机名,port 是 Redis 服务器的端口号,password 是连接密码(如果有)。
操作String(字符串)类型
- 设置键值
要设置一个键值对,请使用SET命令。例如,要将键“name”设置为值“ctt”,可以执行以下操作:
127.0.0.1:6379> SET name ctt
2. 获取键值
要获取键值,请使用GET命令。例如,要获取键“name”的值,可以执行以下操作:
127.0.0.1:6379> GET name
这将返回键“name”的值,“ctt”。
3. 设置过期时间
要为一个键设置过期时间,请使用EXPIRE命令。例如,要将键“name”的过期时间设置为60秒,可以执行以下操作:
127.0.0.1:6379> EXPIRE name 60
查看过期指定key的过期时间,可以用TTL命令
127.0.0.1:6379> TTL name
返回的结果便是剩余时间(到期key会自动删除[目前先这么认为,不同版本的不同角色处理有差异]),如果返回-1,则表示无过期时间
4. 判断键是否存在
要检查一个键是否存在,请使用EXISTS命令。例如,要检查键“name”是否存在,可以执行以下操作:
127.0.0.1:6379> EXISTS name
如果键存在,则返回1;如果键不存在,则返回0。
也可以使用TYPE命令
127.0.0.1:6379> TYPE name
返回对应的类型(如,string)则说明key存在,返回“none”说明key不存在。
还可以用TTL命令判断
127.0.0.1:6379> TTL name
返回对应的时间(>=0的数字),则说明key存在,对应的数字为剩余过期时间;
返回-1,则说明key存在,且key无过期时间;
返回-2,则说明key不存在。
5. 删除键
要删除一个键,请使用DEL命令。例如,要删除键“name”,可以执行以下操作:
127.0.0.1:6379> DEL aaa
6.自增/自减操作
要对一个键进行自增操作,请使用INCR命令。例如,要将键“cnt”自增1,可以执行以下操作:
127.0.0.1:6379> INCR cnt
类似地,要对一个键进行自减操作,请使用DECR命令。
操作哈希表(Hash类型)
Redis中的Hash类型是一个键值对的集合,其中每个键都映射到一个值。下面是Redis中Hash类型的常见操作:
- 设置Hash值
要设置一个Hash值,请使用HSET命令。例如,要将“user”哈希中的“name”字段设置为“ctt”,"age "字段设置为 “29” 可以执行以下操作:
rubyCopy code127.0.0.1:6379> HSET user name "John Doe"
2. 获取Hash值
要获取一个Hash值,请使用HGET命令。例如,要获取“user”哈希中的“name”字段的值,可以执行以下操作:
127.0.0.1:6379> HGET user name
这将返回“ctt”。
3. 获取所有Hash值
要获取所有的Hash值,请使用HGETALL命令。例如,要获取“user”哈希中所有的键值对,可以执行以下操作:
127.0.0.1:6379> HGETALL user
这将返回一个包含所有键值对的列表。
4. 删除Hash值
要删除一个Hash值,请使用HDEL命令。例如,要删除“user”哈希中的age字段,可以执行以下操作:
127.0.0.1:6379> HDEL user age
5.检查Hash值是否存在
要检查一个Hash值是否存在,请使用HEXISTS命令。例如,要检查“user”哈希中是否存在“name”字段,可以执行以下操作:
127.0.0.1:6379> HEXISTS user name
如果存在,将返回1;否则返回0。
6.获取Hash中所有的键
要获取一个Hash中所有的键,请使用HKEYS命令。例如,要获取“user”哈希中的所有键,可以执行以下操作:
127.0.0.1:6379> HKEYS user
这将返回一个包含所有键的列表。
7. 获取Hash中所有的值
要获取一个Hash中所有的值,请使用HVALS命令。例如,要获取“user”哈希中的所有值,可以执行以下操作:
127.0.0.1:6379> HVALS user
这将返回一个包含所有值的列表。
操作列表(list类型)
Redis中的List类型是一个链表结构,其中每个节点都包含一个字符串值。下面是Redis中List类型的常见操作:
- 在列表的头部插入元素
要在列表的头部插入元素,请使用LPUSH命令。例如,要在名为“mylist”的列表的头部插入值为“ctt”的元素,可以执行以下操作:
127.0.0.1:6379> LPUSH mylist ctt
2. 在列表的尾部插入元素
要在列表的尾部插入元素,请使用RPUSH命令。例如,要在名为“mylist”的列表的尾部插入值为“ccc”的元素,可以执行以下操作:
127.0.0.1:6379> RPUSH mylist ccc
3. 获取列表长度
要获取列表的长度,请使用LLEN命令。例如,要获取名为“mylist”的列表的长度,可以执行以下操作:
127.0.0.1:6379> LLEN mylist
这将返回列表的长度。
4. 获取列表中的元素
要获取列表中的元素,请使用LINDEX命令。例如,要获取名为“mylist”的列表中的第一个元素,可以执行以下操作:
127.0.0.1:6379> LINDEX mylist 0
5. 获取列表的范围
要获取列表的一部分,请使用LRANGE命令。例如,要获取名为“mylist”的列表中从第二个到第四个元素之间的元素,可以执行以下操作:
127.0.0.1:6379> LRANGE mylist 1 3
这将返回一个包含第二个到第四个元素之间的所有元素的列表。
6. 删除列表中的元素
要删除列表中的元素,请使用LREM命令。例如,要删除名为“mylist”的列表中的所有值为“ccc”的元素,可以执行以下操作:
127.0.0.1:6379> LREM mylist 0 ccc
7. 弹出列表中的元素
要从列表的头部或尾部弹出元素,请使用LPOP或RPOP命令。例如,要从名为“mylist”的列表的头部弹出一个元素,可以执行以下操作:
127.0.0.1:6379> LPOP mylist
这将弹出并返回列表的第一个元素。
弹出最后一个元素,使用RPOP
取出一个列表里的所有元素,可以执行以下操作:
127.0.0.1:6379> LRANGE mylist 0 -1
无序集合(set类型)操作
Redis中的Set类型是一个无序的、不重复的字符串集合。下面是Redis中Set类型的常见操作:
- 向集合中添加元素
要向集合中添加元素,请使用SADD命令。例如,要将值为“ctt”的元素添加到名为“myset”的集合中,可以执行以下操作:
127.0.0.1:6379> SADD myset ctt
2. 获取集合中的元素数量
要获取集合中的元素数量,请使用SCARD命令。例如,要获取名为“myset”的集合中的元素数量,可以执行以下操作:
127.0.0.1:6379> SCARD myset
3. 获取集合中的所有元素
要获取集合中的所有元素,请使用SMEMBERS命令。例如,要获取名为“myset”的集合中的所有元素,可以执行以下操作:
127.0.0.1:6379> SMEMBERS myset
这将返回一个包含所有元素的列表。
4.判断元素是否在集合中存在
要判断一个元素是否在集合中存在,请使用SISMEMBER命令。例如,要判断值为“ctt”的元素是否存在于名为“myset”的集合中,可以执行以下操作:
127.0.0.1:6379> SISMEMBER myset ctt
如果元素存在于集合中,则返回1;否则返回0。
5. 从集合中删除元素
要从集合中删除元素,请使用SREM命令。例如,要删除名为“myset”的集合中值为“ctt2”的元素,可以执行以下操作:
127.0.0.1:6379> SREM myset ctt2
6.求多个集合的交集、并集或差集
要求多个集合的交集,请使用SINTER命令;要求并集,请使用SUNION命令;要求差集,请使用SDIFF命令。例如,假设有三个集合“set1”、“set2”和“set3”,要求它们的交集,可以执行以下操作:
127.0.0.1:6379> SINTER set1 set2 set3
127.0.0.1:6379> SUNION set1 set2 set3
这将返回一个包含所有集合的交集&并集元素的列表。
这些是Redis中Set类型的一些常见操作。Set类型是一个非常有用的数据结构,可用于存储和处理多个相关但不重复的元素。
有序集合(ZSET类型)操作
Redis中的有序集合(Sorted Set,简称ZSet)是一个非常有用的数据结构,它类似于Set类型,但是每个元素都会关联一个分数(score),且元素按照分数从小到大进行排序。下面是Redis中ZSet类型的常见操作:
- 向有序集合中添加元素
要向有序集合中添加元素,请使用ZADD命令。例如,要将值为“ctt”的元素添加到名为“myzset”的有序集合中,且它的分数为100,可以执行以下操作:
127.0.0.1:6379> ZADD myzset 100 ctt
2. 获取有序集合中的元素数量
要获取有序集合中的元素数量,请使用ZCARD命令。例如,要获取名为“myzset”的有序集合中的元素数量,可以执行以下操作:
127.0.0.1:6379> ZCARD myzset
3.获取有序集合中指定范围内的元素
要获取有序集合中指定范围内的元素,请使用ZRANGE命令。例如,要获取名为“myzset”的有序集合中排名在1到3之间的元素,可以执行以下操作:
127.0.0.1:6379> ZRANGE myzset 0 2
这将返回一个包含指定元素的列表。
4. 获取有序集合中指定分数范围内的元素
要获取有序集合中指定分数范围内的元素,请使用ZRANGEBYSCORE命令。例如,要获取名为“myzset”的有序集合中分数在0到20之间的元素,可以执行以下操作:
127.0.0.1:6379> ZRANGEBYSCORE myzset 0 20
5. 获取有序集合中指定元素的排名
要获取有序集合中指定元素的排名,请使用ZRANK命令。例如,要获取名为“myzset”的有序集合中元素“ttc”的排名,可以执行以下操作:
127.0.0.1:6379> ZRANK myzset ttc
6.获取有序集合中指定元素的分数
要获取有序集合中指定元素的分数,请使用ZSCORE命令。例如,要获取名为“myzset”的有序集合中元素“ctt”的分数,可以执行以下操作:
127.0.0.1:6379> ZSCORE myzset ctt
7. 从有序集合中删除元素
要从有序集合中删除元素,请使用ZREM命令。例如,要删除名为“myzset”的有序集合中元素“a”,可以执行以下操作:
127.0.0.1:6379> ZREM myzset a
8. 查看有序集合中所有元素
使用ZRANGE命令查看有序集合中的所有元素
127.0.0.1:6379> ZRANGE myzset 0 -1
常见的管理命令
- info命令
Redis的INFO命令用于获取有关Redis服务器的各种统计信息和诊断信息。执行INFO命令将返回一个包含大量键值对的文本字符串,其中每个键值对代表一个指标。
以下是一些常见的INFO命令用法和示例:
- 获取Redis服务器的统计信息
要获取Redis服务器的统计信息,可以执行以下命令:
127.0.0.1:6379> INFO [all]
此命令将返回一个包含各种指标的文本字符串,例如内存使用情况、客户端连接数、键数量、命中率等等。
- 获取指定信息分类下的统计信息
可以通过传递参数来指定要检索哪个信息分类的统计信息。例如,要获取Redis服务器的内存使用情况,可以执行以下命令:
127.0.0.1:6379> INFO memory
此命令将返回一个包含有关Redis服务器内存使用情况的各种指标的文本字符串。
- 获取Redis服务器的命令统计信息
要获取Redis服务器的命令统计信息,可以执行以下命令:
127.0.0.1:6379> INFO commandstats
此命令将返回一个包含各种Redis服务器命令的统计信息的文本字符串,例如命令名称、执行次数、执行时间、平均执行时间等等。
- 获取Redis服务器的主从复制信息
要获取Redis服务器的主从复制信息,可以执行以下命令:
127.0.0.1:6379> INFO replication
此命令将返回一个包含有关Redis服务器主从复制状态的各种指标的文本字符串,例如主从节点数量、主节点状态、从节点状态、复制偏移量等等。
- 获取Redis key分布情况
要获取Redis key的分布情况,可以执行以下命令:
127.0.0.1:6379> INFO Keyspace
此命令将返回一个每个库的key的数量、含有过期时间的key的数据以及平均过期时间
2.查看所有已连接的客户端信息
127.0.0.1:6379> client list
此命令将返回当前正在连接的redi实例中的所有客户端的信息
3.监控所有操作命令monitor
例如,在一个客户端执行如下操作
127.0.0.1:6379[2]> select 4
127.0.0.1:6379[4]> set a ctt
127.0.0.1:6379[4]> EXPIRE a 600
127.0.0.1:6379[4]> del bbb
另一个客户端执行monitor命令,则可以看到所有的操作命令
以上为Redis基本操作命令。
相关推荐
- B站收藏视频失效?mybili 收藏夹备份神器完整部署指南
-
本内容来源于@什么值得买APP,观点仅代表作者本人|作者:羊刀仙很多B站用户都有过类似经历:自己精心收藏的视频突然“消失”,点开一看不是“已被删除”,就是“因UP主设置不可见”。而B站并不会主动通知...
- 中间件推荐初始化配置
-
Redis推荐初始化配置bind0.0.0.0protected-modeyesport6379tcp-backlog511timeout300tcp-keepalive300...
- Redis中缓存穿透问题与解决方法
-
缓存穿透问题概述在Redis作为缓存使用时,缓存穿透是常见问题。正常查询流程是先从Redis缓存获取数据,若有则直接使用;若没有则去数据库查询,查到后存入缓存。但当请求的数据在缓存和数据库中都...
- 后端开发必看!Redis 哨兵机制如何保障系统高可用?
-
你是否曾在项目中遇到过Redis主服务器突然宕机,导致整个业务系统出现数据读取异常、响应延迟甚至服务中断的情况?面对这样的突发状况,作为互联网大厂的后端开发人员,如何快速恢复服务、保障系统的高可用...
- Redis合集-大Key处理建议
-
以下是Redis大Key问题的全流程解决方案,涵盖检测、处理、优化及预防策略,结合代码示例和最佳实践:一、大Key的定义与风险1.大Key判定标准数据类型大Key阈值风险场景S...
- 深入解析跳跃表:Redis里的"老六"数据结构,专治各种不服
-
大家好,我是你们的码农段子手,今天要给大家讲一个Redis世界里最会"跳科目三"的数据结构——跳跃表(SkipList)。这货表面上是个青铜,实际上是个王者,连红黑树见了都要喊声大哥。...
- Redis 中 AOF 持久化技术原理全解析,看完你就懂了!
-
你在使用Redis的过程中,有没有担心过数据丢失的问题?尤其是在服务器突然宕机、意外断电等情况发生时,那些还没来得及持久化的数据,是不是让你夜不能寐?别担心,Redis的AOF持久化技术就是...
- Redis合集-必备的几款运维工具
-
Redis在应用Redis时,经常会面临的运维工作,包括Redis的运行状态监控,数据迁移,主从集群、切片集群的部署和运维。接下来,从这三个方面,介绍一些工具。先来学习下监控Redis实时...
- 别再纠结线程池大小 + 线程数量了,没有固定公式的!
-
我们在百度上能很轻易地搜索到以下线程池设置大小的理论:在一台服务器上我们按照以下设置CPU密集型的程序-核心数+1I/O密集型的程序-核心数*2你不会真的按照这个理论来设置线程池的...
- 网络编程—IO多路复用详解
-
假如你想了解IO多路复用,那本文或许可以帮助你本文的最大目的就是想要把select、epoll在执行过程中干了什么叙述出来,所以具体的代码不会涉及,毕竟不同语言的接口有所区别。基础知识IO多路复用涉及...
- 5分钟学会C/C++多线程编程进程和线程
-
前言对线程有基本的理解简单的C++面向过程编程能力创造单个简单的线程。创造单个带参数的线程。如何等待线程结束。创造多个线程,并使用互斥量来防止资源抢占。会使用之后,直接跳到“汇总”,复制模板来用就行...
- 尽情阅读,技术进阶,详解mmap的原理
-
1.一句话概括mmapmmap的作用,在应用这一层,是让你把文件的某一段,当作内存一样来访问。将文件映射到物理内存,将进程虚拟空间映射到那块内存。这样,进程不仅能像访问内存一样读写文件,多个进程...
- C++11多线程知识点总结
-
一、多线程的基本概念1、进程与线程的区别和联系进程:进程是一个动态的过程,是一个活动的实体。简单来说,一个应用程序的运行就可以被看做是一个进程;线程:是运行中的实际的任务执行者。可以说,进程中包含了多...
- 微服务高可用的2个关键技巧,你一定用得上
-
概述上一篇文章讲了一个朋友公司使用SpringCloud架构遇到问题的一个真实案例,虽然不是什么大的技术问题,但如果对一些东西理解的不深刻,还真会犯一些错误。这篇文章我们来聊聊在微服务架构中,到底如...
- Java线程间如何共享与传递数据
-
1、背景在日常SpringBoot应用或者Java应用开发中,使用多线程编程有很多好处,比如可以同时处理多个任务,提高程序的并发性;可以充分利用计算机的多核处理器,使得程序能够更好地利用计算机的资源,...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)