Redis常用操作命令整理 redis 常用命令
wptr33 2024-12-18 17:33 21 浏览
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基本操作命令。
相关推荐
- SpringBoot 3 + Flutter3 实战低代码运营管理-10章
-
获课》aixuetang.xyz/5075/三天构建运营管理系统:SpringBoot3+Flutter3高效开发方法论...
- SpringBoot探针实现:从零构建应用健康监控利器
-
SpringBoot探针实现:从零构建应用健康监控利器声明本文中的所有案例代码、配置仅供参考,如需使用请严格做好相关测试及评估,对于因参照本文内容进行操作而导致的任何直接或间接损失,作者概不负责。本文...
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
-
一、JobRepository是谁?——批处理的“档案馆”JobRepository是SpringBatch的“记忆中枢”,负责记录所有Job和Step的执行状态。它像一位严谨的档案管理员,把任务执...
- 还在为 Spring Boot3 技术整合发愁?一文解锁大厂都在用的实用方案
-
你在使用SpringBoot3开发后端项目时,是不是常常陷入这样的困境?想提升项目性能和功能,却不知道该整合哪些技术;好不容易选定技术,又在配置和使用上频频踩坑。其实,这是很多互联网大厂后端开发...
- 一文吃透!Spring Boot 项目请求日志记录,这几招你绝对不能错过!
-
在互联网应用开发的高速赛道上,系统的稳定性、可维护性以及安全性是每一位开发者都必须关注的核心要素。而请求日志记录,就如同系统的“黑匣子”,能够为我们提供排查故障、分析用户行为、优化系统性能等关键信息...
- spring-boot-starter-actuator简单介绍
-
SpringBootActuator是SpringBoot的一个功能强大的子项目,它提供了一些有用的监控和管理SpringBoot应用程序的端点。SpringBootActuat...
- 使用SpringBoot钩子或Actuator实现优雅停机
-
服务如何响应停机信号在java中我们可以直接利用通过Runtime...
- 28-自定义Spring Boot Actuator指标
-
上篇我们学习了《27-自定义SpringBootActuator健康指示器》,本篇我们学习自定义SpringBootActuator指标(Metric)。...
- 如何在Spring Boot中整合Spring Boot Actuator进行服务应用监控?
-
监控是确保系统稳定性和性能的关键组成部分,而在SpringBoot中就提供了默认的应用监控方案SpringBootActuator,通过SpringBootActuator提供了开箱即用的应...
- 「Spring Boot」 Actuator Endpoint
-
Actuator官网地址:https://docs.spring.io/spring-boot/docs/2.5.6/reference/html/actuator.html目的监控并管理应用程序...
- Spring Boot Actuator监控功能全面剖析
-
SpringBootActuator监控功能全面剖析在现代企业级Java开发中,SpringBoot以其轻量化、高效率的特性深受开发者青睐。而作为SpringBoot生态系统的重要组成部分,S...
- 1000字彻底搞懂SpringBootActuator组件!
-
SpringBootActuator组件SpringBootActuator通过HTTPendpoints或者JMX来管理和监控SpringBoot应用,如服务的审计、健康检查、指标统计和...
- JavaScript数据类型(javascript数据类型介绍)
-
基本数据类型BooleanNullNumberStringSymbolUndefined对象数据类型ObjectArray定义:JavaScript数组是内置的对象之一,它可以用一个变量来存储多个同种...
- 能运行,不代表它是对的:5 个潜伏在正常功能下的 JavaScript 错误
-
JavaScript的动态性和复杂性意味着,代码虽然表面上正常运行,但一些深层次、隐蔽的陷阱往往让人意想不到,梳理了几个JavaScript开发中难以发现的隐蔽错误,旨在帮助我们写出更健壮、更可...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- SpringBoot 3 + Flutter3 实战低代码运营管理-10章
- SpringBoot探针实现:从零构建应用健康监控利器
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
- Github霸榜的SpringBoot全套学习教程,从入门到实战,内容超详细
- 还在为 Spring Boot3 技术整合发愁?一文解锁大厂都在用的实用方案
- 一文吃透!Spring Boot 项目请求日志记录,这几招你绝对不能错过!
- spring-boot-starter-actuator简单介绍
- 使用SpringBoot钩子或Actuator实现优雅停机
- 28-自定义Spring Boot Actuator指标
- 如何在Spring Boot中整合Spring Boot Actuator进行服务应用监控?
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)