VsCode 调试 MySQL 源码

  1. 启动 MySQL

  2. 查看 MySQL 进程号

bash 复制代码
[root@ ~]# ps -ef | grep mysqld
root     21479     1  0 Nov01 ?        00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/data/mysqld.pid
root     26622 21479  0 Nov03 ?        03:03:35 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=root --log-error=/usr/local/mysql/data/mysqld.log --pid-file=/usr/local/mysql/data/mysqld.pid --socket=/usr/local/mysql/data/mysql.sock --port=3306
root     28442 28363  0 10:35 pts/3    00:00:00 grep --color=auto mysqld
  1. 使用 VsCode 打开 MySQL 源码

  2. 配置 launch.json 文件,内容如下:

bash 复制代码
{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "configurations": [
        {
            //"preLaunchTask": "initialize",
            "name": "Debug mysqld",
            "type": "cppdbg",
            //"request": "launch",
            "request": "attach",
            //在此处直接添加进程号即可,或者直接点击调试按钮在提示窗口输入进程号
            "pid": "21180",       
            // "program": "${workspaceFolder}/bld/bin/mysqld",
            "program": "/usr/local/mysql/bin/mysqld",
            "args": [
                "--defaults-file=/etc/my.cnf", "--debug=d,info:F:L","--user=mysql"
            ],
            "cwd": "${workspaceFolder}"
        }
    ]
}
  1. 点击调试运行按钮
  1. 点击 Debug mysqld
  1. 输入上述查询的 MySQL 进程号,回车
  1. 进入 MySQL 调试环境
  1. 在 VsCode 中手动设置断点

  2. 在终端执行 SQL 命令,即可调试

相关推荐
PyAIGCMaster20 分钟前
文本模式下成功。ubuntu P104成功。
服务器·数据库·ubuntu
drebander32 分钟前
MySQL 查询优化案例分享
数据库·mysql
初晴~1 小时前
【Redis分布式锁】高并发场景下秒杀业务的实现思路(集群模式)
java·数据库·redis·分布式·后端·spring·
盖世英雄酱581361 小时前
InnoDB 的页分裂和页合并
数据库·后端
YashanDB3 小时前
【YashanDB知识库】XMLAGG方法的兼容
数据库·yashandb·崖山数据库
独行soc3 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍11基于XML的SQL注入(XML-Based SQL Injection)
数据库·安全·web安全·漏洞挖掘·sql注入·hw·xml注入
小林coding3 小时前
阿里云 Java 后端一面,什么难度?
java·后端·mysql·spring·阿里云
风间琉璃""4 小时前
bugkctf 渗透测试1超详细版
数据库·web安全·网络安全·渗透测试·内网·安全工具
drebander4 小时前
SQL 实战-巧用 CASE WHEN 实现条件分组与统计
大数据·数据库·sql
IvorySQL4 小时前
IvorySQL 4.0 发布:全面支持 PostgreSQL 17
数据库·postgresql·开源数据库·国产数据库·ivorysql