这篇文章为你 Redis 知识面来个查漏补缺

Redis 是什么

Redis 是开源,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。它支持多种类型的数据结构,如 字符串strings, 散列 hashes, 列表 lists, 集合 sets, 有序集合 sorted sets 与范围查询, bitmaps, hyperloglogs 和地理空间(geospatial) 索引半径查询。

Redis 还内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动 分区(Cluster)提供高可用性(high availability)。

嗯,没错这就是 redis 中文官方网站上面的介绍,简洁明了。

NoSQL 是什么

我们知道 redis 是一种非关系型数据库 NoSQL 。而为什么出现 NoSQL?NoSQL 又是什么呢?

单机数据库的年代

在一个网站访问量不大的时候,我们使用一个数据库就足以应对流量请求。

缓存 + 拆分

随着访问量的上升,一个数据库已经不能满足我们的需求了。为了更高的性能,我们在中间加上了一个缓存层并且将数据库做了集群、结构优化和读写分离。

而这里的缓存就是 NoSQL,当然做缓存也只是 NoSQL 的一种功能,就像 Redis 并不仅仅有缓存这一种功能。比如它还能实现 简单的消息队列,解决Session共享,计数器,排行榜,好友关系处理 等等功能,可见 Redis 是一个非常强大工具,让我们来学习它吧!

Redis 通用命令

首先我们抛开数据类型来讲关于 Redis 的通用命令。

操作 key 和 value

Redis 是一种 key value 存储的缓存数据库,所有的数据都有一个自己唯一的key。

这里为了方便演示,我使用了字符串相关的设置命令

  • keys [pattern] 获取符合要求的所有key。时间复杂度为 O(n),一般在生产环境中不使用,因为 Redis 是单线程的,执行耗时的任务会阻塞其他任务。一般会使用 scan 命令替代(非阻塞)。

  • dbsize 获取当前存储数据个数。
  • exists key 判断是否存在该key
  • del key 删除指定数据
  • type key 获取指定key的数据类型
  • rename key newkey 重命名

过期时间

Redis 中很多数据都是用来作为缓存数据的,而作为缓存就需要有过期时间,在 Redis 中提供了很强大的过期时间设置功能。

  • expire key seconds 为某个 key 设置过期时间。
  • ttl key 查看某个 key 的剩余时间,返回正数代表剩余的时间,-1代表永久,-2代表已过期或不存在。

Redis 的五种基本数据类型

在上面我说到了很多 Redis 作为缓存能实现的其他功能,比如计数器,排行榜,好友关系等,这些实现的依据就是靠着 Redis 的数据结构。在整个 Redis 中一共有五种基本的数据结构(还有些高级数据结构以后会讲),他们分别是 字符串strings, 散列 hashes, 列表 lists, 集合 sets, 有序集合 sorted sets。

字符串 string

在绝大部分编程语言中都有 String 字符串类型,对于作为数据库的 Redis 也是必不可少的。

  • set key value 设置值
  • get key 获取某个key的值
  • mset key1 value1 key2 value2 批量设置并且是原子的,可以用来减少网络时间消耗
  • mget key1 key2 批量获取并且是原子的,可以用来减少网络时间消耗

  • incr key 自增指定key的值
  • decr key 自减指定key的值
  • incrby key value 自增指定数值
  • decrby key value 自减指定数值
  • incrbyfloat key floatvalue 增加指定浮点数,前面几个操作就可以用来实现计数器的功能。

  • setnx key value 如果不存在该key则可以设置成功,否则会失败,加上过期时间限制,则是redis实现分布式锁的一种方式(后面会提到)。
  • set key value xx 与前面相反,如果存在则设置成功,否则失败(相当于更新操作)

hash

其实我们可以理解 hash 为 小型 Redis ,Redis 在底层实现上和 Java 中的 HashMap 差不多,都是使用 数组 + 链表 的二维结构实现的。

不同的是,在 Redis 中字典的值只能是字符串,而且他们 rehash 的方式不一样,在 Redis 中使用的是 渐进式rehash 。

在 rehash 的时候会保留新旧两个 hash 字典,在数据迁移的时候会将旧字典中的内容一点一点迁移到新字典中,查询的同时会查询两个 hash 字典,等数据全部迁移完成才会将新字典代替就字典。

下面我们来看一下关于 hash 的基本操作。

  • hset key field value 设置字典中某个key的值
  • hsetnx key field value 设置字典中某个key的值(不存在的)
  • hmset key field1 value1 field2 value2 … 批量设置
  • hget key field 获取字典中某个key的值
  • hmget key field1 field2 批量获取
  • hgetall key 获取全部

  • hdel key field 删除某个key
  • hexists key field 判断是否存在
  • hlen key 获取指定key对应的字典中的存储个数
  • hvals key 返回所有的value
  • hkeys key 返回所有的key

  • hincrby key field increValue 增加某个value的值(也可以增加负数)
  • hincrbyfloat key field floatValue 增加某个value的值(浮点数)

list

Redis 中的列表相当于 Java 中的 LinkedList(双向链表) ,也就是底层是通过 链表 来实现的,所以对于 list 来说 插入删除操作很快,但 索引定位非常慢。

Redis 提供了许多对于 list 的操作,如出,入等操作,你可以充分利用它们来实现一个 栈 或者 队列。

下面我们来看一下关于 list 的基本操作。

  • lpush key item1 item2 item3… 从左入栈
  • rpush key item1 item2 item3… 从右入栈
  • lpop key 从左出栈
  • rpop key 从右出栈
  • lindex key index 获取指定索引的元素 O(n)谨慎使用
  • lrange key start end 获取指定范围的元素 O(n)谨慎使用

  • count = 0 :删除所有值为value的元素
  • count > 0 :从左到右删除 count 个值为 value 的元素
  • count < 0 :从右到做删除 |count| 个值为 value 的元素
  • linsert key before|after item newitem 在指定元素的前面或者后面添加新元素
  • lrem key count value 删除指定个数值为value的元素
  • ltrim key start end 保留指定范围的元素
  • lset key index newValue 更新某个索引的值

  • blpop key timeout 没有则阻塞(timeout指定阻塞时间 为0代表永久)
  • brpop key timeout 没有则阻塞(timeout指定阻塞时间 为0代表永久) 这两个可以用来实现消费者生产者

总结来说我们可以使用 左入又出或者右入左出 来实现队列,左入左出或者右入右出 来实现栈。

set

Redis 中的 set 相当于 Java 中的 HashSet(无序集合),其中里面的元素不可以重复,我们可以利用它实现一些去重的功能。我们还有对几个集合进行取交集,取并集等操作,这些操作就可以获取不同用户之间的共同好友,共同爱好等等。

下面我们就来看一下关于 set 的一些基本操作。

  • sadd key value 添加元素
  • sdel key value 删除某个元素
  • sismember key value 判断是否是集合中的元素
  • srandmember key count 随机获取指定个数的元素(不会影响集合结构)
  • spop key count 从集合中随机弹出元素(会破坏结合结构)
  • smembers key 获取集合所有元素 O(n)复杂度
  • scard key 获取集合个数

  • sinter set1 set2 … 获取所有集合中的交集
  • sdiff set1 set2 … 获取所有集合中的差集
  • sunion set1 set2 … 获取所有集合中的并集

zset

Redis 中的 zset 是一个 有序集合,通过它可以实现很多有意思的功能,比如学生成绩排行榜,视频播放量排行榜等等。

zset 中是使用 跳表 来实现的,我们知道只有数组这种连续的空间才能使用二分查找进行快速的定位,而链表是不可以的。跳表帮助链表查找的时候节省了很多时间(使用跳的方式来遍历索引来进行有序插入),如果不了解跳表的同学可以补习一下。

Redis 中的事务和管道

管道 Pipeline

在某些场景下我们在一次操作中可能需要执行多个命令,而如果我们只是一个命令一个命令去执行则会浪费很多网络消耗时间,如果将命令一次性传输到 Redis 中去再执行,则会减少很多开销时间。

但是需要注意的是 pipeline 中的命令并不是原子性执行的,也就是说管道中的命令到达 Redis 服务器的时候可能会被其他的命令穿插。

事务

关系型数据库具有 ACID 特性,Redis 能保证A(原子性)和I(隔离性),D(持久性)看是否有配置 RDB或者 AOF 持久化操作,但无法保证一致性,因为 Redis 事务不支持回滚。

我们可以简单理解为 Redis 中的事务只是比 Pipeline 多了个原子性操作,也就是不会被其他命令给分割,如上图。

  • multi 事务开始的标志
  • exec 事务执行

  • discard 清除在这个事务中放入队列的所有命令,即解除整个事务。
  • watch key 在事务开始前监控某个元素,如果在提交事务的时候发现这个元素的值被其他客户端更改了则事务会运行失败。
  • unwatch key 解除监控

Redis常用命令总结

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/257450.html<

(0)
管理的头像管理
上一篇2025-05-01 18:55
下一篇 2025-05-01 18:56

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注