面试突击 | Redis 如何从海量数据中查询出某一个 Key?视频版

作者 | 王磊

面试突击 | 第 001 期

1 考察知识点

本题考察的知识点有以下几个:

  1. Keys 和 Scan 的区别

  2. Keys 查询的缺点

  3. Scan 如何使用?

  4. Scan 查询的特点

2 解答思路

  1. Keys 查询存在的问题

  2. Scan 的使用

  3. Scan 的特点

3 Keys 使用相关

1)Keys 用法如下

2)Keys 存在的问题

  1. 此命令没有分页功能,我们只能一次性查询出所有符合条件的 key 值,如果查询结果非常巨大,那么得到的输出信息也会非常多;

  2. keys 命令是遍历查询,因此它的查询时间复杂度是 o(n),所以数据量越大查询时间就越长。

4 Scan 使用相关

我们先来模拟海量数据,使用 Pipeline 添加 10w 条数据,Java 代码实现如下:

import redis.clients.jedis.Jedis;
import redis.clients.jedis.Pipeline;
import utils.JedisUtils;public class ScanExample {public static void main(String[] args) {// 添加 10w 条数据initData();}public static void initData(){Jedis jedis = JedisUtils.getJedis();Pipeline pipe = jedis.pipelined();for (int i = 1; i < 100001; i++) {pipe.set("user_token_" + i, "id" + i);}// 执行命令pipe.sync();System.out.println("数据插入完成");}
}

我们来查询用户 id 为 9999* 的数据,Scan 命令使用如下: 

127.0.0.1:6379> scan 0 match user_token_9999* count 10000
1) "127064"
2) 1) "user_token_99997"
127.0.0.1:6379> scan 127064 match user_token_9999* count 10000
1) "1740"
2) 1) "user_token_9999"
127.0.0.1:6379> scan 1740 match user_token_9999* count 10000
1) "21298"
2) 1) "user_token_99996"
127.0.0.1:6379> scan 21298 match user_token_9999* count 10000
1) "65382"
2) (empty list or set)
127.0.0.1:6379> scan 65382 match user_token_9999* count 10000
1) "78081"
2) 1) "user_token_99998"2) "user_token_99992"
127.0.0.1:6379> scan 78081 match user_token_9999* count 10000
1) "3993"
2) 1) "user_token_99994"2) "user_token_99993"
127.0.0.1:6379> scan 3993 match user_token_9999* count 10000
1) "13773"
2) 1) "user_token_99995"
127.0.0.1:6379> scan 13773 match user_token_9999* count 10000
1) "47923"
2) (empty list or set)
127.0.0.1:6379> scan 47923 match user_token_9999* count 10000
1) "59751"
2) 1) "user_token_99990"2) "user_token_99991"3) "user_token_99999"
127.0.0.1:6379> scan 59751 match user_token_9999* count 10000
1) "0"
2) (empty list or set)

从以上的执行结果,我们看出两个问题:

  1. 查询的结果为空,但游标值不为 0,表示遍历还没结束;

  2. 设置的是 count 10000,但每次返回的数量都不是 10000,且不固定,这是因为 count 只是限定服务器单次遍历的字典槽位数量 (约等于),而不是规定返回结果的 count 值。

相关语法:scan cursor [MATCH pattern] [COUNT count]

其中:

  • cursor:光标位置,整数值,从 0 开始,到 0 结束,查询结果是空,但游标值不为 0,表示遍历还没结束;

  • match pattern:正则匹配字段;

  • count:限定服务器单次遍历的字典槽位数量 (约等于),只是对增量式迭代命令的一种提示 (hint),并不是查询结果返回的最大数量,它的默认值是 10。

5 Scan 代码实战

本文我们使用 Java 代码来实现 Scan 的查询功能,代码如下:

import redis.clients.jedis.Jedis;
import redis.clients.jedis.Pipeline;
import redis.clients.jedis.ScanParams;
import redis.clients.jedis.ScanResult;
import utils.JedisUtils;public class ScanExample {public static void main(String[] args) {Jedis jedis = JedisUtils.getJedis();// 定义 match 和 count 参数ScanParams params = new ScanParams();params.count(10000);params.match("user_token_9999*");// 游标String cursor = "0";while (true) {ScanResult<String> res = jedis.scan(cursor, params);if (res.getCursor().equals("0")) {// 表示最后一条break;}cursor = res.getCursor(); // 设置游标for (String item : res.getResult()) {// 打印查询结果System.out.println("查询结果:" + item);}}}
}

以上程序执行结果如下:

查询结果:user_token_99997

查询结果:user_token_9999

查询结果:user_token_99996

查询结果:user_token_99998

查询结果:user_token_99992

查询结果:user_token_99994

查询结果:user_token_99993

查询结果:user_token_99995

查询结果:user_token_99990

查询结果:user_token_99991

查询结果:user_token_99999

6 总结

通过本文我们了解到,Redis 中如果要在海量的数据数据中,查询某个数据应该使用 Scan,Scan 具有以下特征:

  1. Scan 可以实现 keys 的匹配功能;

  2. Scan 是通过游标进行查询的不会导致 Redis 假死;

  3. Scan 提供了 count 参数,可以规定遍历的数量;

  4. Scan 会把游标返回给客户端,用户客户端继续遍历查询;

  5. Scan 返回的结果可能会有重复数据,需要客户端去重;

  6. 单次返回空值且游标不为 0,说明遍历还没结束;

  7. Scan 可以保证在开始检索之前,被删除的元素一定不会被查询出来;

  8. 在迭代过程中如果有元素被修改, Scan 不保证能查询出相关的元素。

7 视频版

【END】

近期热文

 
  • 阿里巴巴2020招聘正式启动!附内推和微信联系信息

  • 面试珍藏:最常见的200多道Java面试题(2019年最新版)

  • 阿里面试官给你的一些忠告,这样做肯定错不了!附视频

  • Java面试详解(2020版):500+ 面试题和核心知识点详解

关注下方二维码,订阅更多精彩内容

朕已阅 

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

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

相关文章

面经 | 我是如何拿到阿里offer的?附面试题+视频

作者 | rhwayfunn来源 | http://dwz.win/2JK本文来自 rhwayfunn 本人自述&#xff1a;拿到阿里实习offer&#xff0c;经历了5次面试&#xff0c;其中4轮技术面&#xff0c;1轮HR面试。在这里分享一下自己的面试经验和学习总结。希望能够帮助更多的小伙伴。我本科毕业于中南大学…

SCOM 2012知识分享-9:配置警报解决状态

适应平台&#xff1a;System Center 2012 RTM/SP1-------------------------------------------------------------------------------------------------------------设置警报的解决状态在操作控制台中&#xff0c;请单击监视。单击任何视图&#xff0c;将显示警告&#xff0c…

Linux debian ubuntu安装GIMP软件

一、GIMP简介 名称由GNU Image Manipulation Program&#xff08;GNU图像处理程序&#xff09;的首字母组成&#xff0c;是一个自由及开放原始码的点阵图图像编辑器&#xff0c;用于图像照片润饰及编辑、自由绘图、调整大小、裁剪、相片蒙太奇、装换图像格式以及其他专业任务。…

面试突击 002 | Redis 是如何处理已过期元素的?

1 面试题 Redis 如何处理已过期的元素&#xff1f;2 涉及知识点 此问题涉及以下知识点&#xff1a;过期删除策略有哪些&#xff1f;这些过期策略有哪些优缺点&#xff1f;Redis 使用的是什么过期策略&#xff1f;Redis 是如何优化和执行过期策略的&#xff1f;3 答案 常见的过期…

Linux debian安装PyCharm教程、配置pyqt5开发环境

一、PyCharm下载 首先需要下载一个PyCharm社区版压缩包&#xff1a;pycharm-community-2021.1.3.tar.gz。 Linux PyCharm社区版下载 二、PyCharm安装 1.我们最好在普通用户下解压并启动这个软件。如果你在超级用户下启动&#xff0c;你的pycharm就不能输入中文了&#xff0c…

10大iOS开发者最喜爱的类库

该10大iOS开发者最喜爱的库由“iOS辅导团队”成员Marcelo Fabri组织投票选举而得&#xff0c;参与者包括开发者团队&#xff0c;iOS辅导团队以及行业嘉宾。每个团队都要根据以下规则选出五个最好的库&#xff1a;1&#xff09;不能投自己写的库&#xff1b;2&#xff09;排除大…

面试突击第 3 期 | Redis 如何实现查询附近的人?视频实战版

这是我的第 33 篇原创文章作者 | 王磊 &#xff08;javacn666&#xff09;1 面试问题 Redis 如何实现查询附近的人&#xff1f;2 相关面试问题 Redis 中如何操作位置信息&#xff1f;GEO 底层是如何实现的&#xff1f;如何在程序实现查询附近的人&#xff1f;在实际使用中需要注…

Linux debian ubuntu的PyCharm无法正常输入中文

debian ubuntu中 PyCharm 当全拼输入2~3个汉字时&#xff0c;会被强行打断&#xff0c;然后就无法继续输入(也无法切换中英文)&#xff0c;并且汉字下会有下划线。 解决方案&#xff1a; 1.点击PyCharm菜单 “Help ->Edit Custom VM options…” 2.添加 -Drecreate.x11.in…

面试突击 004 | 如何排查 Redis 中的慢查询?视频实战篇

这是我的第 34 篇原创文章作者 | 老王&#xff08;javacn666&#xff09;1 面试题如何排查 Redis 中的慢查询&#xff1f;2 涉及相关问题 Redis 中有没有慢查询排查工具或者相关排查手段&#xff1f;慢查询日志都包含哪些信息&#xff1f;慢查询的相关配置项有哪些&#xff1f;…

[转]Android 之 Window、WindowManager 与窗口管理

这篇是对前两天研究的悬浮窗的内容的一个小小的资料整理吧。首先是转载一篇介绍Android窗口的内容&#xff0c;觉得写得不错&#xff1a;http://blog.csdn.net/xieqibao/article/details/6567814 为防止丢失还是把内容也拷一遍吧(*^__^*) 嘻嘻…… 其实在android中真正展示给用…

面试突击 005 | Redis 是如何实现高可用的?它的实现方式有哪些?「视频版」

这是我的第 35 篇原创文章作者 | 老王&#xff08;javacn666&#xff09;这部视频的录制、剪辑、做 PPT、写文稿大约花费了 5 个小时的时间&#xff0c;希望这种形式能被更多的人喜欢&#xff0c;希望这篇文章会给你带来更多的价值。1 面试题 Redis 是如何实现高可用的&#xf…

Linux debian安装和使用Navicat16 for MySQL

Navicat是一套快速、可靠并价格相当便宜的数据库管理工具&#xff0c;专为简化数据库的管理及降低系统管理成本而设。它的设计符合数据库管理员、开发人员及中小企业的需要。Navicat 是以直觉化的图形用户界面而建的&#xff0c;让你可以以安全并且简单的方式创建、组织、访问并…

windosw7 Hosts文件的位置

2019独角兽企业重金招聘Python工程师标准>>> 1.Hosts文件的位置 &#xff1a; C:\Windows\System32\drivers\etc\Hosts 一般个人电脑都在这位置&#xff0c; 例如&#xff1a;118.144.78.38 www.51cto.com ip 域名 # Copyright…

Redis都不懂?就别去面试了!聊聊我的Redis新专栏「视频版」

前不久&#xff0c;有一个读者在后台留言&#xff0c;说他面试 Java 开发工程师岗位时&#xff0c;居然大部分的面试问题都是关于 Redis &#xff0c;他都差点都忘记了自己应聘的是 Java 工程师了。而然这种现象在现在的后端面试中很常见&#xff0c;对 Redis 的掌握已经变成了…

Linux Debian Python弹出信息框、警告框和询问框

利用PyCharm开发平台和Python编程语言开发PyQt5界面程序&#xff0c;有时需要弹出信息框、警告框和咨询框&#xff0c;使用win32api和win32con在windows系统可以&#xff0c;但是在Linux系统不可以。为了解决这个问题&#xff0c;可以使用QMessageBox。 # pip install pywin32…

面试突击 | Redis 如何从海量数据中查询出某一个 Key?附视频

1 考察知识点 本题考察的知识点有以下几个&#xff1a; Keys 和 Scan 的区别Keys 查询的缺点Scan 如何使用&#xff1f;Scan 查询的特点 2 解答思路 Keys 查询存在的问题Scan 的使用Scan 的特点 3 Keys 使用相关 1&#xff09;Keys 用法如下 2&#xff09;Keys 存在的问题…

分享两个好用的nosql GUI工具

redis: 真是千呼万唤始出来&#xff0c;终于有了redis gui 谢谢作者&#xff0c;但中文乱码问题貌似还没有解决呀&#xff01; https://github.com/caoxinyu/RedisClient mongoDB: MongoVUE这个还是很完善的 http://www.mongovue.com/ 转载于:https://www.cnblogs.com/tankaixi…

Linux Debian11安装MySQL8详细教程

一、下载MySQL Community Server Debian11使用了MariaDB 在APT的软件包存储库中并没有mysql,在这里下载MySQL Community Server 然后选择Debian时会出现建议使用 Mysql APT Repository。所以我们下载安装 Mysql APT Repository 的方式更新 APT Repository 之后使用 dpkg -i安…

HashMap 为什么会导致 CPU 100%?文章看不懂?来看这个视频吧!——面试突击 006 期...

无论是在实际工作中还是在面试中&#xff0c;HashMap 无疑是使用频率最高的知识点之一&#xff0c;所以我们需要搞懂每一个关于 HashMap 的知识点才行。哈喽&#xff0c;大家好&#xff0c;我是老王&#xff0c;欢迎来到 Java 面试突击&#xff0c;我们今天来开始第 6 期的内容…

Linux debian利用ifconfig查看IP地址

net-tools工具箱包括arp,hostname, ifconfig, netstat, rarp, route, plipconfig, slattach, mii-tool and iptunnel and ipmaddr等命令。 debian系统使用ifconfig命令查看IP 地址时&#xff0c;出现如下提示&#xff1a; 一、查看debian系统是否安装ifconfig命令 使用wherei…