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

相关文章

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

Redis Pipeline(管道) 详解

《RedisPipeline(管道)详解》Pipeline管道是Redis提供的一种批量执行命令的机制,通过将多个命令一次性发送到服务器并统一接收响应,减少网络往返次数(RTT),显著提升执行效率... 目录Redis Pipeline 详解1. Pipeline 的核心概念2. 工作原理与性能提升3. 核

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络