Redis一些简单通用命令和认识常用数据类型和编码方式

通用命令

get() / set()

这是Redis中两个最为核心的命令。

set插入

这里的key 和 value都是字符串,我们可以加双引号 或者单引号,或者不加。 

get查找

如果查询的key值不存在,那么会返回一个 nil ,也就是代表空

 在Redis中命令是不区分大小写的。

这就是Redis最核心的命令和它俩的使用方法了,看起来就像是一个网络版的hash map一样。这也是Redis的一个优势,使用简单 学习成本低。

keys() 

在这里补充一下 Redis全局命令的概念

 Redis支持很多的数据结构,从整体上来说,Redis是键值对结构,key是固定的字符串,但是value实际上会有多种类型,比如:

字符串 哈希表  列表  集合  有序集合,一般来说操作不同的数据结构就会有不同的命令。

而全局命令就是能够搭配任意一个数据结构使用的命令。

keys():用来查询当前服务器上匹配的key。

语法:

KEYS pattern

其中 pattern(模式)是包含特殊符号的字符串。

这个pattern存在的意义是为了描述另外的字符串长什么样

pattern的使用规则:

一般生产环境中是禁止使用keys的,尤其是 keys *。 

 注意:keys 命令的时间复杂度 O(N)的,又因为redis是单线程的,所以当数据量很大时,用 keys * 就把redis阻塞了,无法给其他客户端提供服务。

这样带来的结果往往是灾难性的,因为redis作为缓存,它是挡在mysql前,帮mysql分担请求的,如果此时redis阻塞了,那么请求突然就全打往mysql了,mysql可能会突然承受不主压力而挂掉了,如果mysql也挂了,那整个服务差不多也瘫痪了。 

exists()

exists():判断key是否存在。 这里的key可以是多个。

返回值: 有效key的个数

针对多个key来说,这是挺有用的。

 Redis组织这些key就是按照哈希表的方式来组织的。

关于这个命令的时间复杂度 ,官方给出的是 O(N),但是注意,这里的O(N)中的N指的是我们传入的key的个数,不是传统意义上的O(N)。

有两种写法:

如上,第一种写法查询一次,第二种解法查询两次,那么这两种写法有什么区别呢?

我们始终要记住Redis是 客户端 - 服务器结构的程序,而客户端 与 服务器之间是通过网络来通信的,因此分开的写法会产生更多的轮次的网络通信,导致效率变低。

del()

删除指定的key

可以一次删除一个或者多个

时间复杂度 : (N)跟exists一样

返回值:删掉的key的个数 

而Redis删除数据的严重性要看应用场景

不过归根结底还是不要乱删数据。 

expire()

给指定的key设置过期时间

 

语法:

EXPIRE key seconds

 成功时返回1,失败时返回0

其中seconds的单位是秒。

这个key得是之前就有的,不然这个命令就会执行失败。

时间复杂度 O(1)

这个命令在有时间限制的场景下应用很广泛,比如手机验证码有效时间。

另外还有关于基于redis实现的分布式锁

补充:

一秒对于计算机来说还是很漫长的,所以还有一个命令 : pexpire ,也就是多加了个p,此时seconds的单位就是毫秒了,用法跟 expire是一样的。

ttl() 

查看指定的key的过期时间。单位:秒级

这里的ttl跟网络IP协议那里的TTL是不一样的。

 返回值:

返回剩余的过期时间。如果该key没有关联过期时间返回-1,如果该key不存在返回-2。

同样还有一个命令 : pttl 。用法一样,不过单位是毫秒。 

补充: Redis的key过期策略

Redis的过期策略是怎么实现的呢? 这也是一道经典的面试题。

如果直接遍历所有key的方式来检查哪些key过期了,效率未免太低了。 
对此Redis整体的策略有:

1.定期删除:

周期性的每次抽取一部分key,进行验证过期时间。 Redis会保证这个抽查的速度足够快。

为什么对于定期删除有明确的速度要求,只抽取一部分验证来保证抽查速度快呢?

因为Redis是单线程的程序,它的主要任务都是在单线程中执行的,如果扫描过期的key消耗的时间太多了,就有可能导致正常处理请求命令被阻塞了(产生了类似执行 key * 的效果)。

2.惰性删除:

假设这个key已经过期了,但是暂时还没有删除它,当紧接着后面的一次访问正好用到了这个key,那么服务器就触发了删除key的操作,同时再返回一个nil。

在Redis中这两种删除策略是搭配在一起使用的,但是仍然会存在很多过期的key残留在服务器上,没有及时删除掉,为此Redis还提供了一系列内存淘汰策略。

扩展:

 

 理解定时器的实现原理

1.基于优先级队列/堆 

正常的队列是先进先出,而优先级队列是按照指定的优先级,优先级高的先出。

这个优先级是可以自定义的。

在Redis过期key销毁的场景中,距离过期时间越近,那么优先级就越高。

我们把设置了过期时间的key放入到这个堆中,那么堆顶元素就是最早会过期的key。

此时定时器只要分配一个线程,去检查这个堆顶,查看堆顶的元素是否过期即可。

也就是不需要遍历所有key,而是只需要检查堆顶元素即可。 

另外,检查堆顶元素的周期也不能太短, 对于下一次检查的时间可以设置为:堆顶元素距离过期的时间。在此期间就让这个线程阻塞挂起就可以了。

另外如果新来了一个元素,那么也会唤醒这个线程,会重新设置下一次的检查时间。

2.基于时间轮实现的定时器

 如图,就是一个循环数组,把时间划分成很多小段,划分的粒度要看实际需求。

时间轮运行的时候有一个指针,这个指针每次会按照固定的时间间隔向前移动(这个时间间隔就是我们划分的时间粒度),每走到一个格子上,就会尝试执行这个格子上链表的所有任务,为什么是尝试呢?假设某个key的过期时间超过了这个时间轮能表示的最大时间,那么就会让这个key多转几圈,然后放到对应格子的链表上。并且在执行销毁任务时,还是会检查一下过期时间的,如果发现还没有到就不会销毁的。

 

 type()

返回这个key对应的value的数据类型。

注意:Redis中key的类型只有string。

返回类型:
 返回值为none就是没有这个key。

使用示例:

对于操作链表,插入的命令是 lpush 后面跟元素值;对于集合 插入命令是sadd;对于哈希表,插入命令是hset,可见命令都是不一样的。

 

 常用数据结构

redis常用的数据结构有 字符串,哈希,列表,集合,有序集合。

 

另外Redis在底层实现这些数据结构的时候,会在源码层面针对上面的数据结构的实现进行特定的优化,来达到节省时间/空间的效果,也就是内部具体的数据结构(编码方式)还会有变数。 

 总结:同一个数据类型,背后的编码实现方式可能是不同的,会根据特定的场景进行优化

比如string类型,当value就是一个整数的时候,此时Redis可能直接会使用int来保存。

再比如hash表,当数据元素比较少时,会用一个ziplist来存储,以此来压缩空间,因为当元素比较少时,它遍历的速度也很快。

 关于为什么要压缩?

再看看list set zset

 并且在有序集合那里,底层的实现有跳表,因为有序集合里的元素是带有权值的,当需要在某个权值范围内遍历的时候,用跳表就比较合适。

 并且在list和zset的ziplist那里,从Redis3.2开始,就引入了新的实现方式:quicklist。

可以使用命令

object encoding key

来查询这个key底层的编码方式

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1547212.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【C++位图】构建灵活的空间效率工具

目录 位图位图的基本概念如何用位图表示数据位图的基本操作setresettest 封装位图的设计 总结 在计算机科学中,位图(Bitmap)是一种高效的空间管理数据结构,广泛应用于各种场景,如集合操作、图像处理和资源管理。与传统…

什么是开放式耳机?具有什么特色?非常值得入手的蓝牙耳机推荐

开放式耳机是当下较为热门的一种耳机类型。它具有以下特点: 设计结构: 呈现开放式的构造,不会完全堵住耳道。如此一来,外界声音能够较容易地被使用者听到,在使用耳机时可以保持对周围环境的察觉。比如在户外&#xf…

绿色新纪元:光伏技术飞跃与能源体系重塑

近年来,光伏电池技术取得了突破性进展。新型高效光伏材料如钙钛矿、有机光伏等不断涌现,这些材料在转换效率和稳定性上均表现出色,为光伏产业注入了新的活力。同时,光伏组件的智能化、轻量化设计也日益成为趋势,使得光…

Go基础学习06-Golang标准库container/list(双向链表)深入讲解;延迟初始化技术;Element;List;Ring

基础介绍 单向链表中的每个节点包含数据和指向下一个节点的指针。其特点是每个节点只知道下一个节点的位置,使得数据只能单向遍历。 示意图如下: 双向链表中的每个节点都包含指向前一个节点和后一个节点的指针。这使得在双向链表中可以从前向后或从后…

403高效绕过目录扫描工具

403高效绕过目录扫描工具 简介 在安全测试中,安全测试人员信息收集时可使用此工具来进行目录枚举,目录进行指纹识别,枚举出来的403状态目录可尝试进行绕过,绕过403有可能获取管理员权限,不影响dirsearch原本功能使用。…

提升效率,C4D云渲染教程来了

因为C4D主要搭配的渲染器OCtane和Redshift都是GPU渲染器,阿诺德渲染器也可能直接用GPU渲染,所以大部分C4D渲染农场都支持用RTX2080、3090、4090系列显卡云渲染,云渲染追求速度,分机渲染任务,比如分100台机器渲染一个相…

wireshark1

注意看title,管理员的密码即为答案,那么咱们就直接去过找POST请求的数据包就可以了 找到flag,游戏结束~

TOGAF®架构开发方法:构建数字化转型新时代的正式权威指南

The Open Group与AZone权威出品,值得信赖 《TOGAF架构开发方法》培训课程(点击即可学习) 全球最具影响力的数字化转型架构出品方The Open Group 专注于企业架构师职业发展的平台AZone联合推出 The Open Group:行业领导者的信赖…

每日OJ题_牛客_NC40链表相加(二)_链表+高精度加法_C++_Java

目录 牛客_NC40链表相加(二)_链表高精度加法 题目解析 C代码 Java代码 牛客_NC40链表相加(二)_链表高精度加法 链表相加(二)_牛客题霸_牛客网 题目解析 模拟⾼精度加法的过程,只不过是在链表中模拟。 C代码 /*…

FreeRTOS(四)FreeRTOS列表与列表项

目录 列表 列表项 迷你列表项 列表和列表项的关系 列表相关API函数 列表初始化 列表项初始化 列表项插入 列表项末尾插入 列表项删除 列表遍历 在 FreeRTOS 中,列表(List)和列表项(ListItem)是核心数据结构&…

linux内核双向链表使用list klist

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、list和klist是什么?二、代码示例1.list2.klist 总结 前言 提示:这里可以添加本文要记录的大概内容: linux内核中大量使…

上市一周暴涨20%,美的的出海之路开了个好头

“宁可走错一步,也不能走错半步”,这是美的集团创始人何享健的名言,也代表着美的集团在扩张方面长期以来一贯的风格:稳健。 映射在当下,就是当老对手海尔智家于2020年率先登陆港交所,国际化策略初显成效以…

JavaWeb 13.HTTP协议

和自己的情绪共处,永远保持乐观 —— 24.9.26 一、HTTP简介 HTTP 超文本传输协议 (HTTP-Hyper Text transfer protocol),是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。它于1990年提出&a…

考研数据结构——C语言实现归并排序

包含头文件:程序首先包含了标准输入输出库stdio.h,以便使用printf等函数进行输入输出操作。 定义数组和数组大小:定义了一个宏N,其值为5,表示数组q的长度。数组q被初始化为{5, 3, 8, 4, 2},这是我们要排序…

BFS 解决 FloodFill 算法

BFS 解决 FloodFill 算法 题目一: 图像渲染1. 题⽬链接:2. 题⽬描述:3. 算法思路:4.代码 题目二: 岛屿数量1. 题⽬链接:2. 题⽬描述:3. 算法思路:4.代码 题目三:被围绕的…

论文不会写怎么办?推荐这5款AI论文工具帮你一键搞定!

在当今的学术研究和写作领域,AI论文工具已经成为不可或缺的助手。这些工具不仅能够提高写作效率,还能帮助研究者生成高质量的论文。本文将推荐五款优秀的AI论文工具,并特别推荐千笔-AIPassPaper,以帮助读者更好地完成学术写作任务…

OJ在线评测系统 后端 判题机模块预开发 架构分析 使用工厂模式搭建

判题机模块预开发(架构师)(工厂模式) 判题机模块 是为了把代码交个代码沙箱去处理 得到结果返回 代码沙箱 梳理判题模块和代码沙箱的关系 判题模块:调用代码沙箱 把代码和输入交给代码沙箱去执行 代码沙箱:只负责接受代码和输入 返回编译的结果 不负…

初始化的代码块和@PostConstruct有什么区别

背景 在实际开发中,我们经常会需要进行一些初始化操作,比如进行一些预加载和赋值之类的。在代码中,常见的有通过静态代码块、非静态代码块,PostConstruct来实现初始化。那么既然他们都可以实现初始化操作,那么他们有什…

Ubuntu 开机自启动 .py / .sh 脚本,可通过脚本启动 roslaunch/roscore等

前言 项目中要求上电自启动定位程序,所以摸索了一种 Ubuntu 系统下开机自启动的方法,开机自启动 .sh 脚本,加载 ROS 环境的同时启动 .py 脚本。在 . py 脚本中启动一系列 ROS 节点。 一、 .sh 脚本的编写 #!/bin/bash # gnome-terminal -- …

JetPack03-ViewModel 保证界面数据稳定性

前提 Activity横竖屏切换后,Activity中的数据会丢失。 因为横竖屏切换后,Activity会销毁重建,生命周期会执行onPause->onStop->onDestroy->onCreate->onStart->onReusme。 简介 ViewModel能保证Activity中数据的稳定性&…