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

相关文章

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的