【Redis】Redis 高性能IO模型原理

这篇具有很好参考价值的文章主要介绍了【Redis】Redis 高性能IO模型原理。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

在面试的时候遇到Redis肯定会问,Redis单线程为什么那么快呀?你可以说下你对IO多路复用的机制嘛。但是仔细一想Redis真的是单线程在运行处理嘛,其实这个单线程主要指的Redis的网络IO和键值对读写是由一个线程来完成的,Redis在处理客户端的请求,包括socket读取、解析、执行、写入socket都由一个顺序串行的主线程处理。但是其他的流程比如说持久化AOF、RDB、集群数据同步等都有别的线程完成。
Redis命令工作线程是单线程的,但是,整个Redis来说,是多线程的;
【Redis】Redis 高性能IO模型原理

Redis为什么用单线程

多线程的开销
程序设计中,一般为了充分利用操作系统底层资源,都需要进行设计多线程编程,但是无脑的使用多线程编程,并不会得到一直较高的系统吞吐率。因为多线程之间存在系统资源的竞争,如果不能合理的设计对共享资源的访问,那么就可能出现串行执行的结果。
【Redis】Redis 高性能IO模型原理
在并发编程领域来说,共享资源竞争问题是必须面对的问题,否则处理不好,可能会导致数据出现紊乱。比如同时操作key1,A线程修改为1,B线程修改为2。如何保证同一时间只有一个线程在处理。并且我们需要维护对共享资源的互斥关系,在程序设计需要去考虑这些问题,因此Redis采用单线程。

单线程为什么快?

一是由于本身在内存中操作,并且利用高效的数据结构哈希表,跳表等。二是由于利用了IO多路服用机制来实现在网络IO中可以并发处理大量的客户端请求。

基本IO模型与阻塞点

如果我们操作的是简单的get key1操作,全流程就是首先监听客户端的请求(bind/listen)、Accept(建立连接)、recv(从socket获取数据)、parse(解析数据)、获取数据之后get,最后发送数据写入socket中。
【Redis】Redis 高性能IO模型原理
但是图中,在accept建立连接和recv\send过程可能出现连接建立被阻塞,或者从socket中获取不到数据。

非阻塞模式

在Socket模型中,不同的操作会返回不同的套接字类型,socket()会返回套接字,接着调用listen()返回监听套接字,然后调用accept()返回已连接套接字。
【Redis】Redis 高性能IO模型原理
当我们调用accept()套接字,如果一直没有请求建立连接,那么不会一直等待,而是返回去操作其他请求。

IO多路复用模型

IO多路复用是指一个线程可以处理多个IO流,Redis在单线程运行的情况下,可以同时监听多个套接字和已连接套接字,一旦有请求到达,Redis线程就可以处理。
FD就是多个套接字,
【Redis】Redis 高性能IO模型原理
上述流程一个线程进行监听套接字,当有对应的套接字发生时,出发对应的事件写入到对应的事件队列中,然后通过对应的事件回调函数进行处理。
但是这里其实也设计到了网络编程中的模型,以及对应的同步、异步、阻塞、非阻塞
BIO、NIO、IO多路复用,对应的select、poll、epoll等由于涉及的东西比较多,这个我在下一篇文章中具体解释下。

小结

本篇主要介绍了Redis为什么执行快,已经引入多线程的存在的问题。最后引入IO多路复用机制。文章来源地址https://www.toymoban.com/news/detail-443791.html

到了这里,关于【Redis】Redis 高性能IO模型原理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 高性能网络设计秘笈:深入剖析Linux网络IO与epoll

    本文分享自华为云社区《高性能网络设计秘笈:深入剖析Linux网络IO与epoll》,作者: Lion Long 。 epoll是Linux内核中一种可扩展的IO事件处理机制,可替代select和poll的系统调用。处理百万级并发访问性能更佳。 (1) 文件描述符越多,性能越差。 单个进程中能够监视的文件描述

    2024年02月16日
    浏览(50)
  • .NET 高性能I/O之道:深度探索 System.IO.Pipelines

    🏆作者:科技、互联网行业优质创作者 🏆专注领域:.Net技术、软件架构、人工智能、数字化转型、DeveloperSharp、微服务、工业互联网、智能制造 🏆欢迎关注我(Net数字智慧化基地),里面有很多 高价值 技术文章, 是你刻苦努力也积累不到的经验 ,能助你快速成长。升职

    2024年03月11日
    浏览(56)
  • Redis核心数据结构实战与高性能解析

    目录 一、安装Redis 二、Redis线程与高性能 2.1 Redis是单线程么? 2.2 Redis读写是单线程为何这么快? 2.3 Redis如何处理并发操作命令? 三、核心数据结构实战 3.1 字符串常用操作实战 SET 存入键值对 SETNX SETEX MSET 批量存入键值对 MSETNX DECR 原子减1 DECRBY 原子减 INCR 原子加1 INCRBY 原子

    2024年02月07日
    浏览(54)
  • 高性能分布式缓存Redis(三) 扩展应用

    在并发编程中,通过锁,来避免由于竞争而造成的数据不一致问题 问题分析 现象:本地锁在多节点下失效(集群/分布式) 原因:本地锁它只能锁住本地JVM进程中的多个线程,对于多个JVM进程的不同线程间是锁不住的 解决:分布式锁(在分布式环境下提供锁服务,并且达到本地

    2024年02月12日
    浏览(72)
  • Redis实现高性能的全文搜索引擎---RediSearch

    RediSearch是一个Redis模块,为Redis提供查询、二次索引和全文搜索,他的性能甚至比es还要高。 注意端口号不要和redis冲突了:

    2024年02月16日
    浏览(61)
  • “深入理解Redis:高性能缓存和数据存储技术解析“

    标题:深入理解Redis:高性能缓存和数据存储技术解析 摘要:本文将深入探讨Redis作为一种高性能缓存和数据存储技术的原理和用法。我们将从Redis的基本特性入手,介绍其在缓存和数据存储方面的优势,并通过实际示例代码展示如何使用Redis提升应用程序的性能和可靠性。

    2024年02月16日
    浏览(53)
  • “深入理解Redis:高性能缓存与数据存储的秘密“

    标题:深入理解Redis:高性能缓存与数据存储的秘密 在现代应用程序的开发中,缓存和数据存储是非常重要的组成部分。它们不仅可以提高应用程序的性能,还可以减轻数据库和网络的负载。其中,Redis作为一种高性能的内存数据存储系统,因其出色的性能和灵活的特性而备

    2024年02月16日
    浏览(46)
  • Kafka 高可靠高性能原理探究

    在探究 Kafka 核心知识之前,我们先思考一个问题: 什么场景会促使我们使用 Kafka?  说到这里,我们头脑中或多或少会蹦出 异步解耦 和 削峰填谷等字样,是的,这就是 Kafka 最重要的落地场景。 异步解耦 :同步调用转换成异步消息通知,实现生产者和消费者的解耦。想象一

    2024年02月04日
    浏览(40)
  • “深入解析Redis:高性能缓存与分布式数据存储“

    标题:深入解析Redis:高性能缓存与分布式数据存储 摘要:本文将深入解析Redis,介绍其作为高性能缓存和分布式数据存储的特点和功能,并提供示例代码展示其使用方法。 正文: 一、引言 Redis是一个开源的内存数据结构存储系统,它以其高性能、灵活的数据结构以及丰富的

    2024年02月17日
    浏览(59)
  • 基于 Redis 实现高性能、低延迟的延时消息的方案演进

    🎉欢迎来系统设计专栏:基于 Redis 实现高性能、低延迟的延时消息的方案演进 📜其他专栏:java面试 数据结构 源码解读 故障分析 🎬作者简介:大家好,我是小徐🥇 ☁️博客首页:CSDN主页 小徐的博客 🌄每日一句: 好学而不勤非真好学者 📜 欢迎大家关注! ❤️ 随着

    2024年01月22日
    浏览(70)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包