• Linux搭建redis调试环境


    一、Linux环境搭建

    1.1、安装VSCode

    进入VsCode官网下载对应版本的安装包,以ubuntu的安装包(.dep)为例。
    (1)安装。

    sudo dpkg -i xxxx.dep
    
    • 1

    执行信息:

    正在选中未选择的软件包 code。
    (正在读取数据库 ... 系统当前共安装有 234542 个文件和目录。)
    正准备解包 code_1.72.2-1665614327_amd64.deb  ...
    正在解包 code (1.72.2-1665614327) ...
    正在设置 code (1.72.2-1665614327) ...
    正在处理用于 gnome-menus (3.13.3-6ubuntu3.1) 的触发器 ...
    正在处理用于 desktop-file-utils (0.22-1ubuntu5.2) 的触发器 ...
    正在处理用于 bamfdaemon (0.5.3~bzr0+16.04.20180209-0ubuntu1) 的触发器 ...
    Rebuilding /usr/share/applications/bamf-2.index...
    正在处理用于 mime-support (3.59ubuntu1) 的触发器 ...
    正在处理用于 shared-mime-info (1.5-2ubuntu0.2) 的触发器 ...
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    (2)启动VSCode,进入VSCode扩展安装C/C++插件。
    vscode_c_and_cpp

    1.2、加载redis源码

    (1)下载redis源码。

    git clone https://gitee.com/mirrors/redis.git -b 6.0
    
    • 1

    (2)使用VSCode打开下载的redis文件夹。
    (3)在redis文件夹下的.vscode创建tasks.json和launch.json。
    tasks.json

    {
        "tasks": [
            {
                "type": "cppbuild",
                "label": "build-redis",
                "command": "/usr/bin/make",
                "args": [
                ],
                "options": {
                    "cwd": "${workspaceFolder}"
                },
                "problemMatcher": [
                    "$gcc"
                ],
                "group": {
                    "kind": "build",
                    "isDefault": true
                },
                "detail": "调试器生成的任务。"
            }
        ],
        "version": "2.0.0"
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    launch.json

    {
        // 使用 IntelliSense 了解相关属性。 
        // 悬停以查看现有属性的描述。
        // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
        "version": "0.2.0",
        "configurations": [
            {
                "name": "启动 redis",
                "type": "cppdbg",
                "request": "launch",
                "program": "${workspaceFolder}/src/redis-server",
                "args": ["redis.conf"],
                "stopAtEntry": false,
                "cwd": "${workspaceFolder}",
                "environment": [],
                "externalConsole": false,
                "MIMode": "gdb",
                "setupCommands": [
                    {
                        "description": "为 gdb 启用整齐打印",
                        "text": "-enable-pretty-printing",
                        "ignoreFailures": true
                    },
                    {
                        "description": "将反汇编风格设置为 Intel",
                        "text": "-gdb-set disassembly-flavor intel",
                        "ignoreFailures": true
                    }
                ],
                "preLaunchTask": "build-redis",
                "miDebuggerPath": "/usr/bin/gdb"
            }
        ]
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    (4) 启动调试。
    start_debug
    (5)设置断点就可以进行调试了。

    二、Windows环境搭建

    (1)按照虚拟机(VMware+Ubuntu)和vscode。
    (2)在 vscode 安装 remote-ssh和remote-ssh:editing Configuration Files插件,连接到虚拟机。
    (3)vscode安装C/C++和C/C++ Extension Pack插件。
    (4)根据个人喜好,vscode安装其他插件:vscode-lua、cmake、Project Manager。
    remote_ssh
    cpp_and_c
    lua_vscode
    cmake_vscode
    pm_vscode

    三、redis 调用堆栈介绍

    启动调试后,在调用堆栈有redis启动的相关线程。可以看到redis不是单线程的,所说的redis单线程是指命令处理、逻辑处理是单线程。就是不管有多少条连接去操作redis的数据,redis对命令的处理都在一个线程完成。

    redis不是单线程
    redis-server
    主线程
    命令处理
    网络事件的监听
    bio_close_file
    后台线程,异步关闭大文件
    bio_aof_fsync
    后台线程,aof持久化, 异步刷盘
    bio_lazy_free
    异步清理大块内存
    io_thd_1
    IO操作线程
    io_thd_2
    IO操作线程
    io_thd_3
    IO操作线程
    jemalloc_bg_thd
    jemalloc后台线程,内存池管理
    1. redis-server是主线程,所说的redis是单线程主要指redis-server这个线程,用于处理命令。
    2. bio开头的线程是后台IO线程,bio_close_file的作用是关闭大文件。比如调用close(fd)时,当fd对应的文件比较大时,就会通过这个线程来关闭文件。redis做持久化时,需要将内存中的数据刷到磁盘中,redis会fork一个子进程,在子进程中进行持久化,持久化过程中产生的rdb文件储存着内存中的数据,这个rdb文件是一个比较大的文件,这就涉及到关闭大文件的问题,redis就是通过bio_close_file线程来关闭大文件。
    3. bio开头的线程是后台IO线程,bio_aof_fsync是aof持久化(当前redis进程中直接进行刷盘)刷盘后台线程。即当前命令和数据在当前进程、线程直接刷到磁盘中。
    4. io_thd_* 是redis支持的开启多个线程进行读写IO操作。
    5. jemalloc_bg_thd是redis使用的内存池,做内存管理相关工作。

    在这里插入图片描述

  • 相关阅读:
    【QML】 如何将Qt Design Studio 创建的UI项目转换为应用程序
    旅游企业该怎么进行网络品牌推广呢?如何宣传和规划旅游商品?
    如何自学java怎么入门?我有秒招
    基于Qlearning强化学习的机器人路线规划仿真
    基于卷积神经网络实现手写数字识别
    新版onenet平台安全鉴权的确定与使用
    哈希原理及模拟实现并封装unordered系列关联式容器
    【历史上的今天】8 月 2 日:字节跳动收购 Musical.ly;PlayStation 之父诞生;早期的女性计算机先驱
    并发编程详解: 十三个工具类, 十大设计模式, 从理论基础到案例实战
    【Vue3】定义全局变量和全局函数
  • 原文地址:https://blog.csdn.net/Long_xu/article/details/127407983