Redis远程字典服务器(10)—— 渐进式命令与数据库管理命令

2024-08-23 06:52

本文主要是介绍Redis远程字典服务器(10)—— 渐进式命令与数据库管理命令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,关于渐进式命令

  1. 我们之前讲过keys命令,可以把一次性把整个Redis的所有key都获取到,所以这个操作比较“危险”,可能会一下子得到太多的key,从而阻塞Redis服务器
  2. 通过渐进式命令,就能做到:既能获取到所有的key,同时又不会卡死服务器。
  3. 所谓渐进式:不是一个命令把所有key都拿到,而是每执行一次命令,只获取到其中的一部分,这样就保证这样一次操作不会太卡,要想得到所有的key,就要多次执行渐进式命令
  4. 渐进式遍历其实是一组命令,但是这一组命令的使用方法是一致的,其中的代表命令就是:scan

二,scan命令基本用法 

scan cursor count

cursor表示“光标”:光标指向了当前遍历的位置,count就是一次遍历多少个,如下图:

 光标设为0,就意味着从头开始遍历;返回值的前半部分,是告诉你下次继续遍历时,光标会从哪里开始遍历

三,scan详细介绍

上面的scan的最基本用法,接下来来详细介绍下这个命令 :SCAN | Docs (redis.io)

scan cursor [MATCH pattern] [COUNT count] [TYPE type]
  • cursor:只是一个字符串,长得像数字而已,不能代表下标
  • MATCH pattern:这个和keys命令是一样的,就是keys后面的那些筛选条件:Redis远程字典服务器(2) —— 全局命令-CSDN博客
  • COUNT count:限制这一次遍历能够获取到多少个元素,默认是10(此处的count和MySQL的limit不一样,limit是精确的,此处的count只是给Redis服务器的一个“提示”/“建议”,写入的count和实际返回的key不一定是相同的,但不会差很多)
  • TYPE type:key都是string类型,value有很多类型,这个就是获取指定类型的value

下面是scan的使用:

①先创建10个key:

 ②scan的光标从0,开始,一次获取10个key:

③然后加上count选项

 ④type使用也很简单,就不演示了

注意:

  • count的数字,不是说每次遍历都得设置成一样
  • 这里的渐进式遍历,在遍历过程中,不会在服务器里面存储任何的状态信息,所以此处的遍历是可以随时终止的,不会对服务器产生任何副作用
  • 渐进性遍历 scan 虽然解决了阻塞的问题,但如果在遍历期间键有所变化(增加、修改、删 除),可能导致遍历时键的重复遍历或者遗漏,这点务必在实际开发中考虑

 对于上面的第三点要做点补充:不仅仅是Redis,遍历很多东西也是比较忌讳:一边遍历,一遍修改,比如:C++ STL 遍历 + 修改/新增/删除 ==> 迭代器失效

四,数据库管理命令

  1. 在MySQL上有一个很重要的概念,就是database,一个MySQL服务器上可以有很多个database,每个database里面有很多表,并且可以随意 创建/删除 数据库4
  2. 其实Redis也是有database这样的概念的,只是Redis的database是现成的,它给用户提供了16个数据库,编号从0到15,用户不能创建,也不能删除
  3. 这16个数据库中的数据是隔离的,不会相互影响,默认情况下使用的数据库就是0号,使用select index就能切换数据库
  4. 但是实际使用过程中很少关注到数据库,一般默认使用0号即可,有需求再切换数据库

 

DBSIZE

这个命令可以获取到当前数据库里面有多少个key

 

flushdb / flushall 命令⽤于清除数据库,区别在于 flushdb 只清除当前数据库,flushall 会清楚所有数 据库 

 其余的数据库管理命令,可以自己查文档啦,毕竟还有用户名密码等等

这篇关于Redis远程字典服务器(10)—— 渐进式命令与数据库管理命令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1098666

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2