您当前的位置:首页 > 电脑百科 > 数据库 > Redis

Redis基础你掌握多少了?来查漏补缺?

时间:2020-02-26 10:49:50  来源:  作者:

原文出处:https://juejin.im/post/5dc4c5ef5188252af967afd7

redis 是什么

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

Redis还内置了 复制(replication),LUA脚本(Lua ing), 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是一种 keyvalue存储的缓存数据库,所有的数据都有一个自己唯一的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常用命令总结

(试了好几次,图片传上来还是不清晰,需要的朋友就加个人微信:fangzhen0219,我私发吧)

好了,这就是这篇文章全部的内容了,对于 Redis你还有多少遗忘的或者没学习到的呢?欢迎留言区评论



Tags:Redis基础   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
本文将从Redis的基本特性入手,通过讲述Redis的数据结构和主要命令对Redis的基本能力进行直观介绍。之后概览Redis提供的高级能力,并在部署、维护、性能调优等多个方面进行更深...【详细内容】
2020-02-27  Tags: Redis基础  点击:(68)  评论:(0)  加入收藏
原文出处:https://juejin.im/post/5dc4c5ef5188252af967afd7Redis 是什么Redis是开源的 内存中的数据结构存储系统,它可以用作 数据库、 缓存和 消息中间件。 它支持多种类型...【详细内容】
2020-02-26  Tags: Redis基础  点击:(64)  评论:(0)  加入收藏
概念:Redis是用C语言开发的一个开源的高性能键值对数据库。特征: 数据间没有必然的联系 内部采用单线程机制进行工作 高性能 多数据类型支持字符串类型 String列表类型 List散...【详细内容】
2019-11-27  Tags: Redis基础  点击:(102)  评论:(0)  加入收藏
▌简易百科推荐
来源: my.oschina.net/xiaomu0082/blog/2990388首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应现象刚开始当测试抱怨环境响应慢的时候 ,我们重启一下应...【详细内容】
2021-12-08  Java识堂    Tags:Redis   点击:(18)  评论:(0)  加入收藏
我不知道为什么你会选择对特定数量的“错误”(或警告)如此具体。听起来您正在寻找将要发布到 Yahoo! 的某些文章的内容。 Insider (N Foos to Blah for the BlahBlah)。那说:...【详细内容】
2021-12-07  富集云科技有限公司    Tags:Redis   点击:(14)  评论:(0)  加入收藏
目录 一、背景 二、步骤 0.理论支持 1、获取数据 2、结果 3、分析数据并评估大小 三、关于repl-backlog-size 一、背景 repl-backlog-size控制这个环形缓冲区. ​ 主从断...【详细内容】
2021-11-05  弈秋的美好生活    Tags:redis   点击:(41)  评论:(0)  加入收藏
Redis 性能测试是通过同时执行多个命令实现的。1,Redis-benchmarkRedis性能命令:redis性能命令格式: redis-benchmark [option] [option value] redis 性能测试工具可选参数如...【详细内容】
2021-11-02  川石信息    Tags:Redis   点击:(41)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  JavaEdge    Tags:Redis   点击:(28)  评论:(0)  加入收藏
普通java中使用引用Java redis 驱动,即可连接:import redis.clients.jedis.Jedis; public class RedisTestJava { public static void main(String[] args) { //连...【详细内容】
2021-10-13  faesuite    Tags:Redis   点击:(34)  评论:(0)  加入收藏
Redis常用的数据结构有 string list set zset hashstringstring 是 Redis 的基本的数据类型,一个 key 对应一个 value。string 类型是二进制安全的,Redis的string可以包含任...【详细内容】
2021-10-12  语霖    Tags:Redis   点击:(36)  评论:(0)  加入收藏
列表类型可以存储一组按插入顺序排序的字符串,它非常灵活,支持在两端插入、弹出数据,可以充当栈和队列的角色。> LPUSH fruit apple(integer) 1> RPUSH fruit banana(integer)...【详细内容】
2021-09-17  深夜敲代码    Tags:Redis   点击:(54)  评论:(0)  加入收藏
Redis持久化意义 是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去,比如你的redis整个挂了,然后redis就不可用了,你要做的事情是让redis变得可用,尽快变得可用 大量的请...【详细内容】
2021-08-12  小李说IT    Tags:Redis   点击:(77)  评论:(0)  加入收藏
当查询Redis中没有的数据时,该查询会下沉到数据库层,同时数据库层也没有该数据,当这种情况大量出现或被恶意攻击时,接口的访问全部透过Redis访问数据库,而数据库中也没有这些数据...【详细内容】
2021-07-30  随便t    Tags:缓存穿透   点击:(91)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条