开启GDB调试PG数据库编译过程


在PG的编译过程中,缺乏一些关键信息,无法查看到其编译过程或者执行过程中的一些错误,在这里通过GDB的形式来逐步调试

一、编译PG

./configure --enable-debug --enable-cassert
make -j
sudo make install

二、开启gdb

# 停止原本的 postgres
/usr/local/pgsql/bin/pg_ctl -D /opt/postgres-custom/mydb stop
# 用 gdb 启动 postgres
gdb --args /usr/local/pgsql/bin/postgres -D /opt/postgres-custom/mydb

在gdb提示符中输入

(gdb) run

监控

在另一个终端连接数据库:

/usr/local/pgsql/bin/psql -U postgres

在数据库中输入一些指令,例如

CREATE INDEX testidx ON test USING GIST (a);

如果崩溃了,gdb 会自动停止在崩溃点,然后可以查看:

Program received signal SIGUSR1, User defined signal 1.
Download failed: 无效的参数.  Continuing without source file ./misc/../sysdeps/unix/sysv/linux/epoll_wait.c.
0x00007ffff732a007 in epoll_wait (epfd=9, events=0x555555f19600, maxevents=3, timeout=60000)
    at ../sysdeps/unix/sysv/linux/epoll_wait.c:30
warning: 30     ../sysdeps/unix/sysv/linux/epoll_wait.c: 没有那个文件或目录
(gdb) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值