JAVA面试题大全(十七)

JAVA面试题大全(十七)

码农世界 2024-05-27 前端 75 次浏览 0个评论

1、redis 是什么?都有哪些使用场景?

Redis是一个开源的,使用ANSI C语言编写,支持网络,可基于内存,可持久化的日志型,key-value数据库。

  • 数据高并发的读写
  • 海量数据的读写
  • 对扩展性要求高的数据

    2、redis 有哪些功能? 

    • 数据缓存功能
    • 分布式锁的功能
    • 支持数据持久化
    • 支持事务
    • 支持消息队列

      3、redis 和 memcache 有什么区别? 

      • memcache所有的值均是简单的字符串,redis作为其替代者,支持更为丰富的数据类型
      • redis的速度比memcache快很多
      • redis可以持久化其数据

        4、redis 为什么是单线程的? 

        因为 cpu 不是 Redis 的瓶颈,Redis 的瓶颈最有可能是机器内存或者网络带宽。既然单线程容易实现,而且 cpu 又不会成为瓶颈,那就顺理成章地采用单线程的方案了。

        关于 Redis 的性能,官方网站也有,普通笔记本轻松处理每秒几十万的请求。

        而且单线程并不代表就慢。 nginx 和 nodejs 也都是高性能单线程的代表。

        5、redis 支持的数据类型有哪些?

        Redis支持多种数据类型,这些数据类型使得Redis不仅能够处理简单的键值对存储,还能够实现更复杂的数据结构和用例。以下是Redis支持的主要数据类型:

        1. 字符串(Strings):

          • 基本的数据类型,用于存储字符串数据,如用户信息、配置参数等。
        2. 列表(Lists):

          • 列表中的每个元素都是字符串,列表可以作为队列或者栈使用,支持两端添加或移除元素。
        3. 集合(Sets):

          • 无序集合,元素唯一,可以用于存储唯一性的数据集,支持集合操作如交集、并集、差集等。
        4. 有序集合(Sorted Sets):

          • 与集合类似,但每个元素都有一个分数(score)与之关联,可以按照分数对元素进行排序。
        5. 哈希(Hashes):

          • 键值对集合,其中键和值都是字符串,类似于某些编程语言中的字典或哈希表,适合存储对象。
        6. 位图(Bitmaps):

          • 可以将字符串作为位数组,每个位可以是0或1,适合用于实现大型的二进制数组。
        7. 超日志(HyperLogLogs):

          • 用于基数统计,可以用于统计独立用户访问量等场景,具有非常低的空间复杂度。
        8. 地理空间(Geospatial):

          • 用于存储地理位置信息,支持查询位置元素和根据距离排序等操作。
        9. 发布/订阅(Pub/Sub):

          • 一种消息队列模式,允许消息的发布者将消息发布到频道,而订阅者可以订阅一个或多个频道来接收消息。
        10. 流(Streams):

          • Redis 5.0引入的新数据类型,用于消息队列(MQ)系统,支持消息的持久化、自动过期删除等特性。

        这些数据类型使得Redis非常灵活,可以适用于缓存、消息队列、排行榜、实时分析等多种应用场景。

        6、jedis 和 redisson 有哪些区别?

        Jedis是Redis的Java实现的客户端,其API提供了比较全面的Redis命令的支持。

        Redisson实现了分布式和可扩展的Java数据结构,和Jedis相比,功能较为简单,不支持字符串操作,不支持排序、事务、管道、分区等Redis特性。Redisson的宗旨是促进使用者对Redis的关注分离,从而让使用者能够将精力更集中地放在处理业务逻辑上。

        7、redis 支持的 java 客户端都有哪些?

        Redisson、Jedis、lettuce等等,官方推荐使用Redisson。

        8、怎么保证缓存和数据库数据的一致性?

        合理设置缓存的过期时间。

        新增、更改、删除数据库操作时同步更新 Redis,可以使用事物机制来保证数据的一致性。

        9、redis 持久化有几种方式?

        • RDB(Redis Database):指定的时间间隔能对你的数据进行快照存储。
        • AOF(Append Only File):每一个收到的写命令都通过write函数追加到文件中。

          10、redis 分布式锁有什么缺陷? 

          Redis 分布式锁不能解决超时的问题,分布式锁有一个超时时间,程序的执行如果超出了锁的超时时间就会出现问题。

          11、redis 如何做内存优化?

          Redis的内存优化可以通过多种策略和配置选项来实现,以下是一些常用的内存优化方法:

          1. 内存分配器优化:

            • Redis使用特殊的内存分配器如jemalloc来管理内存,这有助于减少内存碎片并提高内存利用率11。
          2. 限制内存大小:

            • 使用maxmemory配置指令来限制Redis可以使用的最大内存量。这可以防止Redis消耗过多服务器内存13。
          3. 内存淘汰策略:

            • 通过maxmemory-policy指令设置内存淘汰策略,如LRU(最近最少使用)或TTL(生存时间)策略,当达到内存上限时Redis将自动淘汰数据14。
          4. 使用合适的数据结构:

            • 根据业务需求选择合适的数据结构,因为不同的数据结构在内存使用上可能存在显著差异15。
          5. 键值对优化:

            • 优化键(key)和值(value)的大小,较短的键和较小的值可以减少内存占用14。
          6. 使用整型:

            • 当可能时,使用整型而不是字符串类型存储数值,这样可以节省内存13。
          7. 共享对象:

            • Redis允许共享一些对象,如小整数,可以通过调整REDIS_SHARED_INTEGERS参数来增加共享对象的数量,从而节省内存13。
          8. 内存回收策略:

            • 利用Redis的惰性删除和定时删除策略来管理过期键值对的内存回收14。
          9. 客户端缓冲区优化:

            • 监控并优化客户端缓冲区的大小,避免因客户端消费不及时导致的内存占用14。
          10. 禁用THP(Transparent Huge Pages):

            • 在Linux系统上,禁用THP特性可以减少内存页的合并,从而降低内存占用13。
          11. 使用物理机而非虚拟机:

            • 在物理机上运行Redis可以避免虚拟化带来的额外内存开销13。
          12. 代码层面优化:

            • 在代码层面,优化对Redis的访问模式,比如减少不必要的缓存键,合理设置键的过期时间等。
          13. 监控和分析:

            • 使用工具监控Redis的内存使用情况,并定期分析内存使用模式,以便进行调整。

          通过这些方法,可以有效地优化Redis的内存使用,提高其性能和稳定性。

          12、redis 常见的性能问题有哪些?该如何解决?

          Redis是一种高性能的内存数据库,但在使用过程中可能会遇到一些性能问题。以下是一些常见的Redis性能问题及其解决方案:

          1. 内存使用过多:

            • 合理设计Key,避免使用过多的Key,可以通过合并多个Key或使用更简洁的Key来减少内存使用27。
            • 定期删除无用数据,通过设置合适的过期时间或使用Lua脚本定期删除无用数据,可以有效控制Redis内存使用27。
          2. 配置不当:

            • 调整内存分配策略,根据实际需求调整maxmemory和maxmemory-policy参数,控制内存使用27。
            • 优化网络设置,调整timeout和tcp-backlog等网络参数,提高网络性能27。
          3. 处理大数据集的性能问题:

            • 使用集群,通过将数据分散到多个Redis节点上,可以提高处理大数据集的能力27。
            • 优化数据结构,选择适合场景的数据结构,如使用有序集合(sorted set)替代列表(list)来优化排序操作27。
          4. Redis自身限制:

            • 升级硬件,通过升级服务器硬件,如增加内存、使用更快的CPU和磁盘等,可以提高Redis的性能27。
            • 优化操作系统设置,调整操作系统的相关参数,如文件描述符数量、网络参数等,以适应Redis的需求27。
          5. 内存碎片问题:

            • 如果使用的是Redis 4.0版本以上,可以通过配置开启自动内存碎片整理来解决26。
            • 内存碎片整理的参数配置需要根据实际情况进行调整,以降低碎片整理期间对Redis性能的影响26。
          6. 集中过期key导致的问题:

            • 增加随机过期时间,把集中过期的时间打散,降低Redis清理过期key的压力26。
            • 开启lazy-free机制,当删除过期key时,把释放内存的操作放到后台线程中执行,避免阻塞主线程26。
          7. 使用Swap导致性能下降:

            • 增加机器的内存,让Redis有足够的内存可以使用。
            • 整理内存空间,释放出足够的内存供Redis使用,然后释放Redis的Swap,让Redis重新使用内存26。
          8. 网络带宽过载:

            • 确认占满网络带宽的Redis实例,如果属于正常的业务访问,需要及时扩容或迁移实例。
            • 对Redis机器的网络流量增加监控,在网络流量达到一定阈值时提前报警,及时确认和扩容26。
          9. 慢查询问题:

            • 尽量避免使用时间复杂度过高的命令,对于数据的聚合操作,放在客户端做26。
            • 执行时间复杂度为O(N)的命令时,保证N尽量小,每次获取尽量少的数据,让Redis可以及时处理返回26。
          10. fork耗时严重:

            • 控制Redis实例的内存在合理范围内,尽量在10G以下,因为fork的耗时与实例大小有关26。
            • 合理配置数据持久化策略,例如在slave节点执行RDB备份,并在低峰期执行26。

          通过上述措施,可以显著提高Redis的性能和稳定性。需要注意的是,Redis性能优化是一个持续的过程,需要不断地对Redis的使用和配置进行优化。

          13、 redis 淘汰策略有哪些?

          • volatile-lru:从已设置过期时间的数据集(server. db[i]. expires)中挑选最近最少使用的数据淘汰。
          • volatile-ttl:从已设置过期时间的数据集(server. db[i]. expires)中挑选将要过期的数据淘汰。
          • volatile-random:从已设置过期时间的数据集(server. db[i]. expires)中任意选择数据淘汰。
          • allkeys-lru:从数据集(server. db[i]. dict)中挑选最近最少使用的数据淘汰。
          • allkeys-random:从数据集(server. db[i]. dict)中任意选择数据淘汰。
          • no-enviction(驱逐):禁止驱逐数据。

            14、redis 怎么实现分布式锁? 

            Redis 分布式锁其实就是在系统里面占一个“坑”,其他程序也要占“坑”的时候,占用成功了就可以继续执行,失败了就只能放弃或稍后重试。

            占坑一般使用 setnx(set if not exists)指令,只允许被一个程序占有,使用完调用 del 释放锁。

转载请注明来自码农世界,本文标题:《JAVA面试题大全(十七)》

百度分享代码,如果开启HTTPS请参考李洋个人博客
每一天,每一秒,你所做的决定都会改变你的人生!

发表评论

快捷回复:

评论列表 (暂无评论,75人围观)参与讨论

还没有评论,来说两句吧...

Top