看看这些Redis知识你全都掌握了吗
mhr18 2024-11-19 06:45 20 浏览 0 评论
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 与前面相反,如果存在则设置成功,否则失败(相当于更新操作)
- getset key newvalue 设置新值并返回旧值
- append key value 为原本内容追加内容
- strlen key 获取字符串长度
- getrange key start end 获取指定范围的内容
- setrange key index value 设置指定范围的内容
- setex key seconds value 设置值且设置过期时间
- set key value ex seconds nx 为不存在的key设置值且设置过期时间,分布式锁的实现方式。
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)谨慎使用
- linsert key before|after item newitem 在指定元素的前面或者后面添加新元素
- lrem key count value 删除指定个数值为value的元素
- count = 0 :删除所有值为value的元素
- count > 0 :从左到右删除 count 个值为 value 的元素
- count < 0 :从右到做删除 |count| 个值为 value 的元素
- ltrim key start end 保留指定范围的元素
- lset key index newValue 更新某个索引的值
- blpop key timeout 没有则阻塞(timeout指定阻塞时间 为0代表永久)
- brpop key timeout 没有则阻塞(timeout指定阻塞时间 为0代表永久) 这两个可以用来实现消费者生产者
总结来说我们可以使用 左入又出或者右入左出 来实现队列,左入左出或者右入右出 来实现栈。
- lpush + lpop = Stack
- rpush + rpop = Stack**
- lpush + rpop = Queue
- rpush + lpop = Queue
- lpush/rpush + ltrim = Capped List (定长列表)
- lpush + brpop = Message Queue (消息队列)
- rpush + blpop = Message Queue (消息队列)
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 中是使用 跳表 来实现的,我们知道只有数组这种连续的空间才能使用二分查找进行快速的定位,而链表是不可以的。跳表帮助链表查找的时候节省了很多时间(使用跳的方式来遍历索引来进行有序插入),如果不了解跳表的同学可以补习一下。
下面我们来看一下关于 zset 的一些基本操作。
- zadd key score element 添加,score用于排序,value需要唯一,由于使用的跳表,时间复杂度为 O(logn)。
- zrem key element 删除某元素 O(1)时间复杂度
- zscore key element 获取某个元素的分数
- zincrby key incrScore element 增加某个元素的分数
- zrange key start end [withscores] 获取指定索引范围的元素 加上withscores则返回分数 O(logn + m)时间复杂度
- zrangebyscore key minScore maxScore [withscores] 获取指定分数范围的元素 加上withscores则返回分数,O(logn + m)时间复杂度
- zcard key 获取有序集合长度
Redis 中的事务和管道
管道 Pipeline
在某些场景下我们在一次操作中可能需要执行多个命令,而如果我们只是一个命令一个命令去执行则会浪费很多网络消耗时间,如果将命令一次性传输到 Redis 中去再执行,则会减少很多开销时间。但是需要注意的是 pipeline 中的命令并不是原子性执行的,也就是说管道中的命令到达 Redis 服务器的时候可能会被其他的命令穿插。
事务
关系型数据库具有 ACID 特性,Redis 能保证A(原子性)和I(隔离性),D(持久性)看是否有配置 RDB或者 AOF 持久化操作,但无法保证一致性,因为 Redis 事务不支持回滚。
我们可以简单理解为 Redis 中的事务只是比 Pipeline 多了个原子性操作,也就是不会被其他命令给分割,如上图。
- multi 事务开始的标志
- exec 事务执行
- discard 清除在这个事务中放入队列的所有命令,即解除整个事务。
- watch key 在事务开始前监控某个元素,如果在提交事务的时候发现这个元素的值被其他客户端更改了则事务会运行失败。
- unwatch key 解除监控
Redis常用命令总结
查看更多内容:MySQL性能优化详解,希望可以帮助到你
- 上一篇:Redis源码剖析之字典(dict)
- 下一篇:Redis数据类型-字符串详解
相关推荐
- 【推荐】一个开源免费、AI 驱动的智能数据管理系统,支持多数据库
-
如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!.前言在当今数据驱动的时代,高效、智能地管理数据已成为企业和个人不可或缺的能力。为了满足这一需求,我们推出了这款开...
- Pure Storage推出统一数据管理云平台及新闪存阵列
-
PureStorage公司今日推出企业数据云(EnterpriseDataCloud),称其为组织在混合环境中存储、管理和使用数据方式的全面架构升级。该公司表示,EDC使组织能够在本地、云端和混...
- 对Java学习的10条建议(对java课程的建议)
-
不少Java的初学者一开始都是信心满满准备迎接挑战,但是经过一段时间的学习之后,多少都会碰到各种挫败,以下北风网就总结一些对于初学者非常有用的建议,希望能够给他们解决现实中的问题。Java编程的准备:...
- SQLShift 重大更新:Oracle→PostgreSQL 存储过程转换功能上线!
-
官网:https://sqlshift.cn/6月,SQLShift迎来重大版本更新!作为国内首个支持Oracle->OceanBase存储过程智能转换的工具,SQLShift在过去一...
- JDK21有没有什么稳定、简单又强势的特性?
-
佳未阿里云开发者2025年03月05日08:30浙江阿里妹导读这篇文章主要介绍了Java虚拟线程的发展及其在AJDK中的实现和优化。阅前声明:本文介绍的内容基于AJDK21.0.5[1]以及以上...
- 「松勤软件测试」网站总出现404 bug?总结8个原因,不信解决不了
-
在进行网站测试的时候,有没有碰到过网站崩溃,打不开,出现404错误等各种现象,如果你碰到了,那么恭喜你,你的网站出问题了,是什么原因导致网站出问题呢,根据松勤软件测试的总结如下:01数据库中的表空间不...
- Java面试题及答案最全总结(2025版)
-
大家好,我是Java面试陪考员最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试题及答案。涉及的内容非常全面,包含:Spring、MySQL、JVM、Redis、Linux、Sprin...
- 数据库日常运维工作内容(数据库日常运维 工作内容)
-
#数据库日常运维工作包括哪些内容?#数据库日常运维工作是一个涵盖多个层面的综合性任务,以下是详细的分类和内容说明:一、数据库运维核心工作监控与告警性能监控:实时监控CPU、内存、I/O、连接数、锁等待...
- 分布式之系统底层原理(上)(底层分布式技术)
-
作者:allanpan,腾讯IEG高级后台工程师导言分布式事务是分布式系统必不可少的组成部分,基本上只要实现一个分布式系统就逃不开对分布式事务的支持。本文从分布式事务这个概念切入,尝试对分布式事务...
- oracle 死锁了怎么办?kill 进程 直接上干货
-
1、查看死锁是否存在selectusername,lockwait,status,machine,programfromv$sessionwheresidin(selectsession...
- SpringBoot 各种分页查询方式详解(全网最全)
-
一、分页查询基础概念与原理1.1什么是分页查询分页查询是指将大量数据分割成多个小块(页)进行展示的技术,它是现代Web应用中必不可少的功能。想象一下你去图书馆找书,如果所有书都堆在一张桌子上,你很难...
- 《战场兄弟》全事件攻略 一般事件合同事件红装及隐藏职业攻略
-
《战场兄弟》全事件攻略,一般事件合同事件红装及隐藏职业攻略。《战场兄弟》事件奖励,事件条件。《战场兄弟》是OverhypeStudios制作发行的一款由xcom和桌游为灵感来源,以中世纪、低魔奇幻为...
- LoadRunner(loadrunner录制不到脚本)
-
一、核心组件与工作流程LoadRunner性能测试工具-并发测试-正版软件下载-使用教程-价格-官方代理商的架构围绕三大核心组件构建,形成完整测试闭环:VirtualUserGenerator(...
- Redis数据类型介绍(redis 数据类型)
-
介绍Redis支持五种数据类型:String(字符串),Hash(哈希),List(列表),Set(集合)及Zset(sortedset:有序集合)。1、字符串类型概述1.1、数据类型Redis支持...
- RMAN备份监控及优化总结(rman备份原理)
-
今天主要介绍一下如何对RMAN备份监控及优化,这里就不讲rman备份的一些原理了,仅供参考。一、监控RMAN备份1、确定备份源与备份设备的最大速度从磁盘读的速度和磁带写的带度、备份的速度不可能超出这两...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 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)