Linux搭建redis调试环境
Linux环境调试redis
- Linux环境搭建
- 安装VSCode
- 加载redis源码
- Windows环境搭建
- redis 调用堆栈介绍
- 后言
Linux环境搭建
安装VSCode
进入VsCode官网下载对应版本的安装包,以ubuntu的安装包(.dep)为例。
(1)安装。
sudo dpkg -i xxxx.dep
执行信息:
正在选中未选择的软件包 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) 的触发器 ...
(2)启动VSCode,进入VSCode扩展安装C/C++插件。
加载redis源码
(1)下载redis源码。
git clone https://gitee.com/mirrors/redis.git -b 6.0
(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"
}
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"
}
]
}
(4) 启动调试。
(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。
redis 调用堆栈介绍
启动调试后,在调用堆栈有redis启动的相关线程。可以看到redis不是单线程的,所说的redis单线程是指命令处理、逻辑处理是单线程。就是不管有多少条连接去操作redis的数据,redis对命令的处理都在一个线程完成。
- redis-server是主线程,所说的redis是单线程主要指redis-server这个线程,用于处理命令。
- bio开头的线程是后台IO线程,bio_close_file的作用是关闭大文件。比如调用close(fd)时,当fd对应的文件比较大时,就会通过这个线程来关闭文件。redis做持久化时,需要将内存中的数据刷到磁盘中,redis会fork一个子进程,在子进程中进行持久化,持久化过程中产生的rdb文件储存着内存中的数据,这个rdb文件是一个比较大的文件,这就涉及到关闭大文件的问题,redis就是通过bio_close_file线程来关闭大文件。
- bio开头的线程是后台IO线程,bio_aof_fsync是aof持久化(当前redis进程中直接进行刷盘)刷盘后台线程。即当前命令和数据在当前进程、线程直接刷到磁盘中。
- io_thd_* 是redis支持的开启多个线程进行读写IO操作。
- jemalloc_bg_thd是redis使用的内存池,做内存管理相关工作。
后言
本专栏知识点是通过<零声教育>的系统学习,进行梳理总结写下文章,对c/c++linux系统提升感兴趣的读者,可以点击链接,详细查看详细的服务:C/C++服务器课程