mysqld mysql-debug_MySQL debug设置

对MySQL进行debug和普通程序有所不同,主要是没有配置文件的情况下直接debug。过程如下:

1. 对源码进行cmake 编译(进入到build文件夹),make -j20,

2. 在build文件夹下,进入mysql-test,运行mtr程序:

./mtr --manual-debug load

3. 上面的mtr相当于和mysqld的沟通进程,后面的参数有个load,其对应的文件为load.test,位置被我创建于mysql源码中的ls ~/AliSQL-5.7/mysql-test/t, 内容是:

CREATE TABLE t1 (S1 INT, S2 INT);

CREATE Index t1_idx on t1(S1);

INSERT INTO t1 VALUES (1, 1);

INSERT INTO t1 VALUES (2, 2);

INSERT INTO t1 VALUES (3, 3);

INSERT INTO t1 VALUES (4, 4);

INSERT INTO t1 VALUES (5, 5);

INSERT INTO t1 VALUES (6, 6);

INSERT INTO t1 VALUES (7, 7);

SELECT * FROM t1 WHERE S1 > 1 and S1 < 5 or S1 > 3 and S1 < 7;

4. 运行了mtr之后,会在屏幕上看到一堆输出的结果,类似于:

--defaults-group-suffix=.1 --defaults-file=/home/michael/AliSQL-5.7/bu/mysql-test/var/my.cnf --log-output=file --gdb --loose-debug-sync-timeout=600 --loose-skip-log-bin --log-syslog=0 --loose-federated=ON --core-file --loose-mysqlx-port=13009

把这堆输出作为mysqld的启动参数

5. mysqld位于build/sql文件夹下(make后就可以看到)

6. 启动客户端

../client/mysql -uroot -S var/tmp/mysqld.1.sock test

通过上述设置,就可以在eclipse中运行调试了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值