2024.1.3 关于 Redis 渐进式遍历 和 数据库管理命令

目录

引言

渐进式遍历 

SCAN 命令

 数据库管理命令

切换数据库

获取数据库 key 个数 

删除数据库所有 key

同步删除 SYNC

异步删除 ASYNC


阅读下述文章之前建议点击下方链接熟悉 keys 命令的用法和特点

Redis 全局通用命令


​​​渐进式遍历 

  • keys * 命令
  • 一次性将 Redis 中所有的 key 都获取到

注意:

  • 执行该命令 十分危险,可能会导致一下子得到太多 key,从而阻塞 Redis 服务器

  • 相较于 keys * 命令
  • 渐进式遍历,可以做到获取到所有的 key 的同时又不会阻塞 服务器

通俗理解:

  • 不是通过一个命令,便将所有的 key 都获取到
  • 而是每执行一次命令,便获取到其中的一小部分 key,以此保证当前这次操作不会阻塞 Redis 服务器
  • 要想得到所有的 key ,仅多执行几次渐进式遍历命令来遍历 Redis 中的 key 即可
  • 类似于 化整为零 的思想

SCAN 命令

  • 渐进式遍历的代表命令

语法:

scan cursor [MATCH pattern] [COUNT count] [TYPE type]
  • cursor 代表光标,而 光标便指向了当前遍历的位置

注意:

  • 此处的 cursor 不能理解成 下标
  • cursor 并不是一个连续递增的整数,仅仅只是一个字符串
  • 程序员 和 Redis 客户端是不认识光标(cursor)这个概念的
  • 只有 Redis 服务器知道光标(cursor)值 所对应的元素位置
  • 我们要做的只能是将返回的光标(cursor)值写入到下次遍历的 scan 命令中,从而获取下次需遍历到的 key

可选项解释

  • [MATCH pattern] 和前面介绍过的 keys 命令中的 pattern 是一样的 
  • pattern 为包含特殊符号的字符串,其存在的意义是去描述 另外的字符串长啥样的
? 匹配任意一个字符
匹配 0 个或者多个任意字符
[ab] 只能匹配到 a b ,别的都不行 相当于给出固定的选项
[^ae] 只有 a、e 匹配不了 其他的都能匹配
[a-e] 匹配 a - e 这个范围内的字符 包含两侧边界

  • [COUNT count] 用来限制这一次遍历能获取到的元素个数,默认为 10 个

注意:

  • 此处的 count 与 MySQL 中的 limit 不同
  • 首先此处的 count 值只能对 Redis 服务器起到一个 "提示" 或 "建议" 的效果,并不代表 Redis 服务器只能返回 count 个 key
  • 即填写的 count 值 和 实际返回的 key 的个数不一定完全相同,但是也不会差很多!
  • 但对于 MySQL 中的 limit 来说,其给出的值是多少,则该 sql 语句便十分精确地返回多少行数据

  • Redis 中的 key 均为 String 类型,但是 value 却有很多种不同的类型
  • [TYPE type] 可利用该选项来控制返回 key 的 value 类型

实例理解

  • 限制一次遍历仅能获取 3个元素


注意点一:

  • 渐进式遍历,在遍历过程中,Redis 服务器不保留任何状态信息
  • 所以此处的遍历 是可以随时进行终止的,因为其不会对 Redis 服务器产生任何影响

注意点二:

  • 渐进式遍历 虽然解决了阻塞的问题
  • 但如果在遍历期间 key 有所变化(增加、修改、删除),这均可能导致遍历时 key 的重复遍历或者遗漏
  • 这点务必在实际开发中考虑!

 数据库管理命令

  • MySQL 中有一个重要的概念 ——> database(数据库)
  • 一个 MySQL 服务器上可以有很多个 database,一个 database 上可以有很多个 table
  • MySQL 上可以随心所欲的 创建、删除 database 和 table

  • Redis 中也有 database 的概念,只不过不像 MySQL 那样随意
  • Redis 中的 database 均是现成的,即用户不能创建新的数据库,也不能删除已有的数据库
  • Redis 默认给我们提供了 16 个数据库,编号为 0-15
  • 这 16 个数据库之间具有隔离性,即这些数据库不会相互影响
  • 默认情况下使用的数据库就是 0号数据库

切换数据库

  • 使用下方命令来切换数据库
select dbIndex

注意:

  • 在实际 Redis 的使用中很少会关注到数据库,一般都是默认使用 0号数据库

实例理解


获取数据库 key 个数 

  • 使用下方命令来获取到当前数据库中 key 的个数
dbsize

实例理解


删除数据库所有 key

  • 使用下方命令来删除 当前数据库 或 全部数据库 的所有 key
FLUSHDB [ASYNC | SYNC] 删除当前数据库中的所有 keyFLUSHALL [ASYNC | SYNC] 删除全部数据库中的所有 key
  • 选项 [ASYNC | SYNC] 为 [异步 | 同步] 的意思

同步删除 SYNC

  • Redis 会在删除数据前,先将数据同步到磁盘上的持久化文件(如 RDB文件)
  • 这意味着在命令执行完成后,你可以确保数据已经被持久化到磁盘上
  • 即使 Redis 服务在之后重启,也能够从磁盘上的数据文件中恢复数据

优点:

  • 数据持久性高

缺点:

  • 会引起一定的性能开销,因为要等待数据写入磁盘

异步删除 ASYNC

  • Redis 会在后台异步删除数据,而不等待数据同步到磁盘上
  • 这意味着在命令执行完成后,数据可能还没有被持久化到磁盘上
  • 这样的操作通常会更快,因为不需要等待磁盘写入的完成

优点:

  • 性能开销小

缺点:

  • 在极端情况下,如果 Redis 在执行异步删除后崩溃,可能会丢失最后一次清空的数据

总结:

  • 异步删除主要关注于提高执行 FLUSHDB 命令的执行速度,即不会引入等待磁盘写入的性能开销
  • 它不会立即将所有数据写入磁盘,而是通过异步的方式在后台完成这个过程
  • 这也是为什么在异步删除的情况下,可以更快地执行清空数据库的操作

实例理解

  • 使用 FLUSHDB 命令

  • 使用 FLUSHALL 命令

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安全狗入选“2023年福建省信息技术应用创新解决方案”名单

近日,福建省数字福建建设领导小组办公室公布了2023年福建省信息技术应用创新解决方案入选项目评选结果。 作为国内云原生安全领导厂商,安全狗凭借综合且具备突出创新水平的方案入选。 厦门服云信息科技有限公司(品牌名:安全狗&…

栈和队列oj题——232. 用栈实现队列

. 个人主页:晓风飞 专栏:LeetCode刷题|数据结构|Linux|C语言 路漫漫其修远兮,吾将上下而求索 文章目录 题目要求:实现 MyStack 类:注意:示例:解释:提示: 解题核心概念数据…

LeetCode刷题---矩阵置零

解题思路: 本题要求原地置换元素 对矩阵进行第一轮遍历,使用第一行第一列来充当该行该列是否要置换为0的标记位,如果第一行或第一列本身就含有零元素,我们使用colZero和rowZero变量来对其标记。如果第i行第j列的那个元素为0&#…

how2heap-2.23-02-fastbin_dup_into_stack

fastbin_dup_into_stack和fastbin_dup没啥区别 https://blog.csdn.net/u014679440/article/details/135383465 仅仅是欲修改的位置&#xff0c;在栈中 #include <stdio.h> #include <stdlib.h>int main() {fprintf(stderr, "This file extends on fastbin_du…

leetcode13 罗马数字转整数

题目描述&#xff1a;罗马数字由七种字符组成&#xff0c;分别为 I、V、X、L、C、D 和 M&#xff0c;对应的数值分别为 1、5、10、50、100、500 和 1000。在一般情况下&#xff0c;小的数字位于大的数字右边&#xff0c;但有特殊情况&#xff0c;如 IV 表示 4&#xff0c;IX 表…

单线圈无刷直流电机驱动芯片选型分析,可应用于笔记本,显卡风散热风扇,变频冷却风扇,打印机风扇等产品上

单线圈无刷直流电机的电机驱动器。 GC1298R/S&#xff0c;GC1262E/S&#xff0c;GC1298R/S&#xff0c;GC1262R/S具有高效的直接PWM控制方式&#xff0c;它可以控制无刷直流电机转速。它集成了最低速度限制模式、可调速度斜率控制模式、软启动模式、风扇转速计、锁保护、自动重…

《剑指offer》数学第一题:数值的整数次方

题目描述&#xff1a; 给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。 思路&#xff1a; 给定一个浮点数求它的整数次方。要考虑到所有的情况&#xff0c;关于指数&#xff0c;如果是0&#xff0c;则结果是1&#xff1b; 指数是1&#xff0c…

CNN——AlexNet

1.AlexNet概述 论文原文&#xff1a;ImageNet Classification with Deep Convolutional Neural Networks 在LeNet提出后&#xff0c;卷积神经网络在计算机视觉和机器学习领域中很有名气。但卷积神经网络并没有主导这些领域。这是因为虽然LeNet在小数据集上取得了很好的效果&am…

C#: Label、TextBox 鼠标停留时显示提示信息

说明&#xff1a;记录在 Label、TextBox 控件上 鼠标停留时显示提示信息的方法。 1.效果图 2.具体实现步骤 1. 在Form 窗口中先创建 Label 并取名&#xff1a;KEY_label &#xff0c;或 TextBox 取名&#xff1a;KEY_textBox 在 Form1 函数中添加初始化代码&#xff0c;如下&…

ssm基于web的素材网的设计与实现+vue论文

基于web的素材网站的设计与实现 摘要 当下&#xff0c;正处于信息化的时代&#xff0c;许多行业顺应时代的变化&#xff0c;结合使用计算机技术向数字化、信息化建设迈进。传统的素材信息管理模式&#xff0c;采用人工登记的方式保存相关数据&#xff0c;这种以人力为主的管理…

C#中使用 async await TaskCompletionSource<T>实现异步逻辑同步写

Task、async 和 await 是 C# 中用于处理异步编程的关键概念。它们一起构成了异步编程的基础。 Task Task 是表示异步操作的抽象&#xff0c;它属于 System.Threading.Tasks 命名空间。Task 可以表示已经完成的任务、正在运行的任务或者尚未开始的任务。通过 Task&#xff0c;…

你的第一个C/S程序

目录 socket服务端代码客户端代码执行结果 socket socket基础知识 服务端代码 import socket import threading import timeMSG_LENGTH 64 DISCONNECTED !CONNECTION CLOSED connections 0#定义服务器地址 server_ip socket.gethostbyname(socket.gethostname()) server…

【设计模式之美】面向对象分析方法论与实现(二):需求到接口实现的方法论

文章目录 一. 进行面向对象设计1. 划分职责>需要有哪些类2. 定义类及其属性和方法3. 定义类与类之间的交互关系4. 将类组装起来并提供执行入口 二. 如何进行面向对象编程&#xff1f;1. 接口实现2. 辩证思考与灵活应用 【设计模式之美】面向对象分析方法论与实现&#xff08…

教育场景数字化中音视频小程序的发展

教育场景数字化逐步成为刚需 2018年以来&#xff0c;国家对在线教育行业的监管收紧&#xff0c;以及受益于 5G 技术的发展&#xff0c;教育科技逐步走向成熟化和规范化。 教育行业的本质是人与人&#xff08;老师与学生、老师与家长&#xff0c;以及更多角色直接的沟通与互动…

【数据结构和算法】小行星碰撞

其他系列文章导航 Java基础合集数据结构与算法合集 设计模式合集 多线程合集 分布式合集 ES合集 文章目录 其他系列文章导航 文章目录 前言 一、题目描述 二、题解 2.1 什么情况会用到栈 2.2 方法一&#xff1a;模拟 栈 三、代码 3.1 方法一&#xff1a;模拟 栈 四…

【LLM+RS】LLM在推荐系统的实践应用(华为诺亚)

note LLM用于推荐主要还是解决推荐系统加入open domain 的知识。可以基于具体推荐场景数据做SFT。学习华为诺亚-技术分享-LLM在推荐系统的实践应用。 文章目录 note一、背景和问题二、推荐系统中哪里使用LLM1. 特征工程2. 特征编码3. 打分排序 三、推荐系统中如何使用LLM四、挑…

共享WiFi贴项目加盟可以解决商家哪些痛点?

近年来&#xff0c;共享WiFi贴项目在共享商业领域引起了广泛关注。作为一种便捷的网络分享工具&#xff0c;共享WiFi贴不仅受到很多人的青睐&#xff0c;更能够为商家带来诸多实际利益。那么&#xff0c;共享WiFi贴项目加盟究竟可以解决商家哪些痛点呢&#xff1f; 共享WiFi贴为…

【C#】知识点实践序列之Lock的锁定代码块

大家好&#xff0c;我是全栈小5&#xff0c;欢迎来到《小5讲堂之知识点实践序列》文章。 2024年第1篇文章&#xff0c;此篇文章是C#知识点实践序列之Lock知识点&#xff0c;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 本篇验证Lock锁定代…

Navicat(数据库可视化软件)安装教程以及连接MYSQL

Navicat安装教程以及连接MYSQL Navicat&#xff08;数据库可视化软件&#xff09;安装流程安装MySQLnavicat连接mysql数据库 Navicat&#xff08;数据库可视化软件&#xff09; Navicat 是一款专门为 MySQL 设计的可视化数据库 GUI 管理工具&#xff0c;我们可以在自己的计算机…

深入浅出Python日志打印

0.引言 在编程过程中&#xff0c;日志记录是一项非常重要的任务&#xff0c;无论是用于调试代码、记录系统运行状态&#xff0c;还是跟踪可能出现的问题&#xff0c;日志都能发挥重要作用。然而&#xff0c;许多开发者习惯使用简单的print语句来记录信息&#xff0c;这种方法虽…