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

相关文章

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li