GDB多线程调试:Redis的IO多线程

Redis采用的网络模型是单线程的Reactor网络模型,异步处理,因为性能很高。
在这里插入图片描述

Reactor先从客户端获取请求,然后dispatch给具体的执行的线程。处理的流程即为read->decode->compute->encode->send。

而Redis的IO多线程的处理时,会构造一个消息队列,上述处理的流程中,只有compute为单线程串行执行,其余过程分发到不同的线程中执行。这意味着命令解析、执行、响应生成等仍然是在主线程中处理的,但是将客户端请求的读取和响应的写入操作可以在多个 I/O 线程中进行。

启用方式:
  • 在 Redis 配置中设置 io-threads-do-readsyes 并指定 I/O 线程的数量(通过 io-threads 选项)

  • 修改分发策略,int item_id = 0; 改为 int item_id = 1; 线程分发时先分发给IO线程而不是主线程中处理。

GDB调试步骤:

  • 确保可执行程序携带调试信息 -g -ggdb

  • 启动调试器: gdb可执行程序 gdb src/redis-server

  • 设置断点 break

    • 收集读任务:break networking.c : 2534

    在这里插入图片描述

    • 分发读任务:break networking.c : 4233

    在这里插入图片描述

    • 处理读任务:break processCommand
    • 收集写任务:break clientInstallWriteHandler
    • 处理写任务:break writeToClient
  • 运行程序:run redis.conf

    • 每一步中列出所有线程:info threads
    • 其中redis-server是主线程
    • io_thd1-3是io线程
  • 控制执行或者打印变量值或者查看调用堆栈

    • next n
    • step s
    • continue c
    • print
    • backtrace bt

最后给大家推荐一个LinuxC/C++高级架构系统教程的学习资源与课程,可以帮助你有方向、更细致地学习C/C++后端开发,具体内容请见 https://xxetb.xetslk.com/s/1o04uB

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

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

相关文章

【C++】:拷贝构造函数和赋值运算符重载

目录 一,拷贝构造函数1. 什么是拷贝构造函数2. 拷贝构造函数的特性3. 实践总结 二,赋值运算符重载2.1 运算符重载2.2 赋值运算符重载 一,拷贝构造函数 1. 什么是拷贝构造函数 拷贝构造函数是特殊的构造函数。是用一个已经存在的对象&#x…

什么是哈希表

为了解力扣第一题自学哈希表,做总结。 哈希函数的原理: 如果输入一个参数,那么哈希函数就会输出一个数字,并且不同的输入会有不同的输出,相同的输入会有相同的输出。例如: 苹果————89 苹果————…

SAP采购订单-条件类型-配置开发步骤

由于采购业务变更,需要创建新的价格类型,并添加新的计算逻辑计算。首先在例程(VOFM)中创建计算逻辑,然后在系统配置(SPRO)中找到配置点,创建新的条件类型‘ZMM00’,创建定价过程‘ZM…

SpringCloud系列(16)--将服务提供者Provider注册进Zookeeper

前言:在上一章节中我们说明了一些关于Eureka自我保护模式,而且自上一章节起关于Eureka的知识已经讲的差不多了,不过因为Eureka已经停更了,为了安全考虑,我们要用还在更新维护的注册中心来取代Eureka,而本章…

Flink面试(2)

Flink面试(1)-CSDN博客 9. Flink 状态如何存储? 在 Flink 中,状态存储 被叫做 StateBackend,它具备两种能力: 在计算过程中提供访问 State 能力,开发者在编写业务逻辑中能够使用 StateBacken…

Python IO流

1.什么是IO? IO(输入/输出)是计算机程序与外部世界进行数据交换的一种方式。在Python中,IO操作通常涉及文件、网络、标准输入和输出等。Python的IO操作可以分为两种类型:文本IO和二进制IO。 文本IO:用于读…

网络数据包嗅探器工具

组织的网络非常庞大,包含服务器、交换机、路由器和接入点等众多节点,由于许多资源和流量不断通过这些节点,因此很难确定大量流量是真实的还是安全攻击的迹象,了解和了解组织的网络流量至关重要,一个有用的资源是网络数…

MySQL--mysql的安装(压缩包安装保姆级教程)

官网下载:www.mysql.com MySQL :: Download MySQL Community Server (Archived Versions) 1.MySQL下载流程: 第一步:点击download, 下滑找到MySQL community(gpl)Downloads>> 第二步:点…

通俗易懂,十分钟让你了解并上手 Docker

通俗易懂,十分钟让你了解并上手 Docker 一、Docker 能拿来解决什么问题二、Docker 的概念与模型1. 容器化技术2. 镜像的概念3. Docker与虚拟机 三. Docker的使用1. 环境安装2. 制作镜像3. 镜像管理(1) 图形界面(2) 命令…

MySQL 8.0性能优化实战培训

课程介绍 【云贝独家】MySQL 性能优化进阶课程,引领你的职业巅峰! 同学们,你们是否被各种工作中的性能问题困扰?是否渴望提升自己在MySQL数据库方面的技术能力,掌握最新最前沿的技术知识呢? 我们讲师为你带…

深度学习中的黑科技:自监督学习(Self-Supervised Learning)

在人工智能领域,深度学习已成为推动技术革新的核心力量。然而,深度学习的一个重要瓶颈是对大量标记数据的依赖性。在这个背景下,自监督学习(Self-Supervised Learning, SSL)作为一种新兴的学习范式,越来越受到研究者的关注。自监督…

Java23种设计模式-创建型模式之工厂方法模式

工厂方法模式(Factory Method Pattern) 一种创建型设计模式,它定义了一个用于创建对象的接口,让子类决定将哪一个类实例化,从而将产品的实例化推迟到子类中。这种模式的主要角色包括: 角色1:抽…

内核技术解析

GitHub - floesen/KExecDD: Admin to Kernel code execution using the KSecDD driver https://security.stackexchange.com/questions/270383/how-does-the-av-inject-their-own-dll-in-each-new-process

spdlog 日志库部分源码说明——让你可以自定义的指定自动切换日志时间

前言 针对 网络上spdlog日志库目前存在的使用方式固定,不能发挥这个库本身应有价值的情况,这里对一些支持场景进行说明,以供初学者省去阅读源码的时间,直接上手使用 涉及源码 在说明过程中使用spdlog库自身提供的使用说明示例&…

Coursera: An Introduction to American Law 学习笔记 Week 03: Property Law

An Introduction to American Law 本文是 https://www.coursera.org/programs/career-training-for-nevadans-k7yhc/learn/american-law 这门课的学习笔记。 文章目录 An Introduction to American LawInstructors Week 03: Property LawKey Property Law TermsSupplemental Re…

主从模式与AI大模型的结合

主从模式是一种分布式计算的模式,其中一个节点作为主节点负责接收和分发任务,其他节点作为从节点负责执行任务并将结果返回给主节点。AI大模型是指参数量非常庞大的人工智能模型,如深度学习的神经网络模型。 将主从模式与AI大模型结合可以实…

Revit二次开发环境Addin和Lookup配置快速上手教程

一、背景 经常有小伙伴被开发环境的配置难倒,总不能让这些兄弟倒在第一步吧,骑士特意做了一个傻瓜式的教学,希望对初学者有所帮助! 二、教程 Revit开发利器Addin和RevitLookup快速安装教学 https://www.bilibili.com/video/BV1…

vue实现弹窗的动态导入(:is=“dialogName“)

组件的动态挂载 弹窗aaa.vue <template><el-dialogwidth"700px "v-dialog-outdestroy-on-closev-if"dialogVisible":title"title":visible"dialogVisible":before-close"hideDialog":close-on-click-modal"…

多功能气象传感器解析

TH-WQX5多功能气象传感器在监测要素上越来越丰富。除了传统的温度、湿度、风速、风向等基本气象要素外&#xff0c;现代的多功能气象传感器还能够监测降雨量、大气压力、光照强度、紫外线强度、土壤温湿度等多种参数。这些数据的获取&#xff0c;使得农业生产者能够更全面地了解…

【计算机系统】

常用的寄存器%rsp、%rip、%rdi、%rsi、%rax有什么特殊作用 %rsp&#xff1a;保存栈顶地址%rip&#xff1a;保存下一条将要被执行的指令的内存地址%rdi&#xff1a;函数第一个参数传参%rsi&#xff1a;函数第二个参数传参%rax&#xff1a;保存函数返回值 程序GDB、GCC、OBJDUMP、…