专栏名称: 芋道源码
纯 Java 源码分享公众号,目前有「Dubbo」「SpringCloud」「Java 并发」「RocketMQ」「Sharding-JDBC」「MyCAT」「Elastic-Job」「SkyWalking」「Spring」等等
今天看啥  ›  专栏  ›  芋道源码

面试回答 Redis 是单线程的所以很快,让我回去等通知....

芋道源码  · 公众号  · Java  · 2024-12-10 09:30
    

主要观点总结

本文主要介绍了Redis的性能优化和线程模型,包括Redis的多线程网络模型设计。

关键观点总结

关键观点1: Redis的I/O模型是单线程的,但为了提高性能,从v4.0开始引入了多线程进行异步任务处理。

Redis最初选择单线程模型是因为CPU通常不是性能瓶颈,瓶颈往往是内存和网络。但随着在线流量的增长,Redis引入了多线程模型以提高网络I/O性能。

关键观点2: Redis的多线程网络模型设计。

Redis的多线程模型包括一个主线程(Main Reactor)和多个I/O线程(Sub Reactors)。主线程负责接受新连接并将其分发给I/O线程进行独立处理。I/O线程负责读取客户端的请求命令,主线程负责执行命令。响应数据由I/O线程写回客户端。

关键观点3: Redis的多线程模型提高了系统的并发性和吞吐量。

通过异步化读取客户端请求和写回响应数据的过程,Redis的多线程模型提高了系统的性能。客户端请求被放入待读取队列,然后由I/O线程读取。执行命令仍然在主线程上进行,这种设计提高了系统的并发性和吞吐量。


文章预览

👉 这是一个或许对你有用 的社群 🐱 一对一交流/面试小册/简历优化/求职解惑,欢迎加入 「 芋道快速开发平台 」 知识星球。 下面是星球提供的部分资料:   《项目实战(视频)》 :从书中学,往事上 “练 ” 《互联网高频面试题》 :面朝简历学习,春暖花开 《架构 x 系统设计》 :摧枯拉朽,掌控面试高频场景题 《精进 Java 学习指南》 :系统学习,互联网主流技术栈 《必读 Java 源码专栏》 :知其然,知其所以然 👉 这是一个或许对你有用的开源项目 国产 Star 破 10w+ 的开源项目,前端包括管理后台 + 微信小程序,后端支持单体和微服务架构。 功能涵盖 RBAC 权限、SaaS 多租户、数据权限、商城、支付、工作流、大屏报表、微信公众号、CRM 等等功能: Boot 仓库:https://gitee.com/zhijiantianya/ruoyi-vue-pro Cloud 仓库:https://gitee.com/zhijiantianya/yudao-cloud ………………………………

原文地址:访问原文地址
快照地址: 访问文章快照
总结与预览地址:访问总结与预览