【GDB】GDB多线程查看线程堆栈|GDB 调试多线程和多进程总结

目录

 GDB多线程查看崩溃时线程的堆栈

线程的查看以及利用gdb调试多线程

GDB 调试多线程和多进程总结

排除步骤

调试多进程

一、gdb的基础知识复习

二、使用gdb调试多进程

三,gdb 调试多线程

四、设置线程名字(便于分析)

linuxGDB下动态链接库的调试

GDB设置线程锁(一个线程动其他不动)


作者:bandaoyu 链接:https://blog.csdn.net/bandaoyu/article/details/120552039

 GDB多线程查看崩溃时线程的堆栈

例子

2021-09-29 16:37:17.931204 7fff637f7700 422708 59 ERROR RDMAStack in polling_start
2021-09-29 16:37:17.931227 7fff637f7700 422708 59 ERROR RDMAStack polling_start start  polling thread:1
[New Thread 0x7fff4475f700 (LWP 423826)]
2021-09-29 16:37:17.937471 7fff637f7700 422708 59 ERROR RDMAStack polling_start start: 1 handle_rx_fun  threads
2021-09-29 16:37:17.937488 7fff637f7700 422708 59 ERROR RDMAStack polling_start start: handle_rx_fun  thread 
[New Thread 0x7fff43f5e700 (LWP 423827)]
2021-09-29 16:37:17.938410 7fff4475f700 423826 18 ERROR RDMAStack max_num:1 bf_num:
2021-09-29 16:37:17.938437 7fff4475f700 423826 18 ERROR RDMAStack busy_polling bf_num: tail:
terminate called without an active exception
2021-09-29 16:37:17.938455 7fff4475f700 423826 18 ERROR RDMAStack max_num:1 bf_num: tail:
2021-09-29 16:37:17.938459 7fff4475f700 423826 18 ERROR RDMAStack busy_polling bf_num: tail:
2021-09-29 16:37:17.938464 7fff4475f700 423826 18 ERROR RDMAStack max_num:1 bf_num: tail:
2021-09-29 16:37:17.938467 7fff4475f700 423826 18 ERROR RDMAStack busy_polling bf_num: tail:
2021-09-29 16:37:17.938473 7fff4475f700 423826 18 ERROR RDMAStack max_num:1 bf_num: tail:
2021-09-29 16:37:17.938476 7fff4475f700 423826 18 ERROR RDMAStack busy_polling bf_num: tail:
2021-09-29 16:37:17.938481 7fff4475f700 423826 18 ERROR RDMAStack max_num:1 bf_num: tail:
2021-09-29 16:37:17.938484 7fff4475f700 423826 18 ERROR RDMAStack busy_polling bf_num: tail:
2021-09-29 16:37:17.938494 7fff4475f700 423826 18 ERROR RDMAStack max_num:1 bf_num: tail:
2021-09-29 16:37:17.938498 7fff4475f700 423826 18 ERROR RDMAStack busy_polling bf_num: tail:Program received signal SIGABRT, Aborted.[Switching to Thread 0x7fff637f7700 (LWP 422708)]
0x00007fffeb4b3387 in raise () from /lib64/libc.so.6

上面表示 程序abort了。abort之前在线程7fff4475f700运行 (abort之前在这个线程,并不一定是这个线程引起的),abort之后程序切换到0x7fff637f7700线程。

(gdb) i  threads 查看线程信息

查看到线程7fff4475f700的 id 是79,而当前在线程12 (前面有*号)

(gdb) i threads
  Id   Target Id         Frame 
  80   Thread 0x7fff43f5e700 (LWP 423827) "io-workerb-0" 0x00007fffefaafc98 in LC_GetThreadIndex (threadId=423827)
    at /home/lcx/ceph-L/src/umm/localcache.c:41  79   Thread 0x7fff4475f700 (LWP 423826) "io-workerb-0" 0x00007fffeb570ccd in poll () from /lib64/libc.so.6
  78   Thread 0x7fff4a05c700 (LWP 423816) "ms_local" 0x00007fffeca95a35 in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
  77   Thread 0x7fff4a85d700 (LWP 423815) "ms_dispatch" 0x00007fffeca95a35 in 

……


  13   Thread 0x7fff62ff6700 (LWP 422709) "io-workerb-1" 0x00007fffeb57bfd3 in epoll_wait () from /lib64/libc.so.6
* 12   Thread 0x7fff637f7700 (LWP 422708) "io-workerb-0" 0x00007fffeb4b3387 in raise () from /lib64/libc.so.6
  11   Thread 0x7fff63ff8700 (LWP 422702) "io-worker-2" 0x00007fffeb57bfd3 in epoll_wait () from 

(gdb) thread 79 切换到线程79

(gdb) thread 79
[Switching to thread 79 (Thread 0x7fff4475f700 (LWP 423826))]
#0  0x00007fffeb570ccd in poll () from /lib64/libc.so.6

(gdb) bt 查看线程 79的调用堆栈 

(gdb) bt
#0  0x00007fffeb570ccd in poll () from /lib64/libc.so.6
#1  0x00007fffec815c3b in co::libgo_poll (fds=0x7fff4475d2b0, nfds=2, timeout=200, nonblocking_check=true)
    at /compiledir/zhangtao/workspace/Libgo/libgo/netio/unix/hook.cpp:84
#2  0x00007fffec80ccdc in poll (fds=0x7fff4475d2b0, nfds=2, timeout=200)
    at /compiledir/zhangtao/workspace/Libgo/libgo/netio/unix/hook.cpp:477
#3  0x00005555562b24cb in RDMADispatcher::busy_polling() ()
#4  0x00007fffebe18360 in ?? () from /opt/h3c/lib/libstdc++.so.6
#5  0x00007fffeca91ea5 in start_thread () from /lib64/libpthread.so.0
#6  0x00007fffeb57b9fd in clone () from /lib64/libc.so.6
(gdb) f 3
#3  0x00005555562b24cb in RDMADispatcher::busy_polling() ()
(gdb) i local
No symbol table info available.
(gdb) f 2
#2  0x00007fffec80ccdc in poll (fds=0x7fff4475d2b0, nfds=2, timeout=200)
    at /compiledir/zhangtao/workspace/Libgo/libgo/netio/unix/hook.cpp:477
477     /compiledir/zhangtao/workspace/Libgo/libgo/netio/unix/hook.cpp: 没有那个文件或目录.
(gdb) i local
tk = 0x0
__FUNCTION__ = "poll"
(gdb) i arg
fds = 0x7fff4475d2b0
nfds = 2
timeout = 200
(gdb) 

线程的查看以及利用gdb调试多线程

转自:线程的查看以及利用gdb调试多线程;https://blog.csdn.net/zhangye3017/article/details/80382496

命令行查看:

//查看当前运行的进程
ps aux|grep a.out
//查看当前运行的轻量级进程
ps -aL|grep a.out
//查看主线程和新线程的关系
pstree -p 主线程id

这里写图片描述

2. 线程栈结构的查看

1. 获取线程ID
2. 通过命令查看栈结构 ps stack 线程ID

  • 0
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值