redis数据共享_redis高级面试题

redis数据共享_redis高级面试题我正在面试间里焦急地等待着,突然听到了门外的脚步声,随即门被打开,穿着干净满脸清秀的青年走了进来,一股男士香水的淡香扑面而来。 面试官:“平时在工作中用过Redis吗?” 我:“用的比较多。”我心中暗

面试官:Redis的共享对象池了解吗?

我正在面试间里焦急地等待着,突然听到了门外的脚步声,随即门被打开,穿着干净满脸清秀的青年走了进来,一股男士香水的淡香扑面而来。

面试官:“平时在工作中用过Redis吗?”

我:“用的比较多。”我心中暗喜,Redis我熟啊,什么五种数据类型、两种持久化方式倒背如流啊。

面试官:“Redis的共享对象池了解吗?”

“这个。。没有太深入了解。”我支支吾吾的说到,手心已经冒出冷汗。

面试官:“回去等消息吧。”

这句话说的干净利落,然后就没有然后了。失败是成功的妈妈,我不气馁,决定马上恶补一下。

共享对象池

创建大量重复的整数类型势必会耗费大量内存,所以在Redis内部维护了一个从0到9999的整数对象池,这就是共享对象池

为了验证和理解,我们使用object refcount命令查看一下对象引用数,效果如下:

127.0.0.1:6379> set one-more-num1 404
OK
127.0.0.1:6379> object refcount one-more-num1
(integer) 2
172.24.130.22:6379> set one-more-num2 404
OK
127.0.0.1:6379> object refcount one-more-num2
(integer) 3

设置one-more-num1为404后,直接使用共享池中的整数对象,所以引用数为2(另外一个引用在对象池上);再设置one-more-num2为404后,引用数变成了3。

不过需要注意的是:当设置最大内存值(maxmemory)并且启用LRU相关淘汰策略(如:volatile-lru、allkeys-lru)时,共享对象池将会被禁止使用。

为什么没有字符串对象池?

共享对象池中一个关键操作是判断对象是否相等。

Redis中只有整数类型的对象池,是因为整数的比较算法的时间复杂度是O(1),也只保留了10000个整数为了防止对象池的过度浪费。

相对而言,字符串的比较算法的时间复杂度是O(n),特别是长字符串的比较更加消耗性能。

而且,整数类型被重复使用的概率很大,字符串被重复使用的概率相比就会小很多很多,所以在Redis中只用整数类型的对象共享池。


面试官你等着瞧吧,今天你对我爱答不理,明天我让你高攀不起,哈哈哈。。。

参考文献:
《Redis设计与实现》
《Redis开发与运维》
《Redis 深度历险:核心原理与应用实践》


竟然已经看到这里了,你我定是有缘人,留下你的点赞关注,他日必成大器。

微信公众号:万猫学社

微信扫描二维码

关注后回复「电子书」

获取12本Java必读技术书籍

redis数据共享_redis高级面试题

原文地址:https://www.cnblogs.com/heihaozi/archive/2022/03/08/15978999.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5458.html

(0)
上一篇 2023-05-08
下一篇 2023-05-08

相关推荐

  • 免费网络爬虫软件推荐

    免费网络爬虫软件推荐网络爬虫是一种自动化程序,用于自动抓取互联网上的信息。这些信息可以是网页、图片、视频、文本等各种形式的数据。网络爬虫是非常有用的工具,可以大大减少人工获取信息的时间和工作量。

    2024-09-08
    22
  • MSSQL – 最佳实践「建议收藏」

    MSSQL – 最佳实践「建议收藏」MSSQL – 最佳实践 – 使用SSL加密连接 author: 风移 摘要 在SQL Server安全系列专题月报分享中,往期我们已经陆续分享了:如何使用对称密钥实现SQL Server列加密技术、

    2022-12-26
    153
  • MySQL必知必会–第十章–计算字段

    MySQL必知必会–第十章–计算字段第十章–计算字段 1.字段:字段(field) 基本上与列(column)的意思相同,经常互换使用,不过数据库列一般称为列,而术语字段通常用在计算字段的 连接上。 2.拼接字段:将值联结到一起构成…

    2023-02-17
    156
  • 2. 函数「建议收藏」

    2. 函数「建议收藏」聚集函数 count([distinct]列名) 统计某列的值总和 sum([distinct]列名) 统计一列的和(注意必须是数字类型的) avg([distinct]列名) 计算一列的平均值(注意

    2023-05-26
    158
  • SQL Server内置的HTAP技术「终于解决」

    SQL Server内置的HTAP技术「终于解决」SQL Server内置的HTAP技术 目录 背景 SQL Server在OLAP上的发展 SQL Server的初代HTAP SQL Server逐渐增强的HTAP SQL Server列存总结 H

    2023-05-09
    136
  • conda与pip的区别

    conda与pip的区别conda与pip是python中两个常用的包管理工具。pip是python的包管理工具,主要用于管理和安装python的第三方库和模块。而conda是Anaconda中的包管理工具,是一个开源的跨平台环境管理系统,旨在解决多语言依赖问题。本文将阐述conda和pip在功能、依赖管理、平台支持、环境管理等方面的区别和优劣。

    2024-07-04
    48
  • python删除读取错误的图片(python报错图片)

    python删除读取错误的图片(python报错图片)估计是你没有关闭打开的图片,文件被占用,所以无法删除。

    2023-11-28
    131
  • Python中elif的使用方法

    Python中elif的使用方法在Python中,codeelif/code语句用于多条件结构的判断,常与codeif/code语句搭配使用。

    2024-05-07
    63

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注