pstack 分析Nacos 失败 |Debug日志
2021/10/2 23:12:40
本文主要是介绍pstack 分析Nacos 失败 |Debug日志,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
pstack 分析Nacos 失败 |Debug日志
现象
在Ubuntu下安装pstack后,使用 sudo pstack nacos进程的PID
命令跟踪堆栈报错
解决问题
centOS则没有这种问题,我以Ubuntu pstack
为关键词搜索,没有找到相关的安装教程,但是找到了
pstack 命令打印不出堆栈 无法正常使用-问答-阿里云开发者社区-阿里云 (aliyun.com)
他和我遇见的情况类似。
操作不允许,没有那个进程
没有权限,要么这个进程做了保护。
于是我加上sudo
,结果在process处是????,并不是数字。
后面又找到了
aliyun ubuntu pstack无法使用的问题解决 crawl: Input/output error_chenycbbc0101的博客-CSDN博客
他提示pstack可能存在乱码
在Linux下,一切皆文件,于是使用 nano /usr/bin/pstak
打开pstack文件
果然乱码,于是删除pstack文件,并且新建一个pstack文件,copy对应脚本内容并赋权限
#删除pstack sudo rm -rf pstack #新建pstack文件并copy sudo nano pstack #copy脚本放在下一个代码框,太长了影响观感 #赋权限 chmod -R 777 pstack #再次查询nacos进程 sudo pstack nacos的进程PID
结果
用nano写入的pstack中的内容
#!/bin/sh if test $# -ne 1; then echo "Usage: `basename $0 .sh` <process-id>" 1>&2 exit 1 fi if test ! -r /proc/$1; then echo "Process $1 not found." 1>&2 exit 1 fi # GDB doesn't allow "thread apply all bt" when the process isn't # threaded; need to peek at the process to determine if that or the # simpler "bt" should be used. backtrace="bt" if test -d /proc/$1/task ; then # Newer kernel; has a task/ directory. if test `/bin/ls /proc/$1/task | /usr/bin/wc -l` -gt 1 2>/dev/null ; then backtrace="thread apply all bt" fi elif test -f /proc/$1/maps ; then # Older kernel; go by it loading libpthread. if /bin/grep -e libpthread /proc/$1/maps > /dev/null 2>&1 ; then backtrace="thread apply all bt" fi fi GDB=${GDB:-/usr/bin/gdb} if $GDB -nx --quiet --batch --readnever > /dev/null 2>&1; then readnever=--readnever else readnever= fi # Run GDB, strip out unwanted noise. $GDB --quiet $readnever -nx /proc/$1/exe $1 <<EOF 2>&1 | set width 0 set height 0 set pagination no $backtrace EOF /bin/sed -n \ -e 's/^\((gdb) \)*//' \ -e '/^#/p' \ -e '/^Thread/p'
这篇关于pstack 分析Nacos 失败 |Debug日志的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享