pstack使用和原理[通俗易懂]

pstack使用和原理[通俗易懂]pstack使用和原理http://www.cnblogs.com/mumuxinfei/p/4366708.html前言:  最近小组在组织深入剖析Nginx>>的读书会,里面作者提到了pstack这个工具.之前写JAVA程序,对jstack这个工具,非常的喜欢,觉得很有用.于是想比较下pstack和jstack的异同.   和jstack一样,psta

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

pstack使用和原理

http://www.cnblogs.com/mumuxinfei/p/4366708.html

前言:
  最近小组在组织<<深入剖析Nginx>>的读书会, 里面作者提到了pstack这个工具. 之前写JAVA程序, 对jstack这个工具, 非常的喜欢, 觉得很有用. 于是想比较下pstack和jstack的异同. 
  和jstack一样, pstack亦能展现进程的线程堆栈快照, 非常方便验证和性能评估. 本文用来简单展示下pstack的使用方式和原理.

pstack使用
  pstack使用非常的简单, 让我们写个简易多线程程序:
  pstack使用和原理[通俗易懂]
  编译执行后, 使用pstack体验下:
  pstack使用和原理[通俗易懂]
  注: 大秘密, sleep函数貌似是基于nanosleep实现的, ^_^.
  这边我们能清楚的看到两个线程在执行线, 以及当前线程的详细函数栈信息.
  对pstack的作用, 大致可以归纳如下:
  1). 查看线程数(比pstree, 包含了详细的堆栈信息)
  2). 能简单验证是否按照预定的调用顺序/调用栈执行
  3). 采用高频率多次采样使用时, 能发现程序当前的阻塞在哪里, 以及性能消耗点在哪里?
  4). 能反映出疑似的死锁现象(多个线程同时在wait lock, 具体需要进一步验证)

  当然还能举例更多的作用, 相信使用过jstack的coder, 必然深以为然.

pstack原理:
  pstack用途很大, 那其背后的原理是啥?
  可以观察发现, 其实pstack是/usr/bin/gstack的软链接, 而gstack本身是基于gdb封装的shell脚本.
  pstack使用和原理[通俗易懂]
  让我们简单分析下这个强大的shell脚本:
  pstack使用和原理[通俗易懂]
  注: 由于代码太长, 这边选取最核心的片段, backtrace=”thread apply all bt”
  shell采用了here document的方式, 完成了GDB的交互工作(注意EOF标识, 及范围内的交互命令). 
  重要的是输入thread apply all bt这个交互命令. 该命令要求输出所有的线程堆栈信息.
  对GDB输出的结果, 通过管道并借助sed命令进行了替换和过滤.

总结:
  pstack其实是gdb的一个功能封装, 但其实现的功能, 确实非常实用. 本文讲述了pstack使用和原理, 以及常见的用途, 下文将讲述死锁检测的一种机制, 欢迎关注.

写在最后:
  
如果你觉得这篇文章对你有帮助, 请小小打赏下. 其实我想试试, 看看写博客能否给自己带来一点小小的收益. 无论多少, 都是对楼主一种由衷的肯定.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193958.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月15日 上午11:22
下一篇 2025年11月15日 下午12:01


相关推荐

  • Idea 配置JDK 版本 Idea 配置JDK1.8

    Idea 配置JDK 版本 Idea 配置JDK1.8Idea 配置 JDK 版本 Idea 配置 JDK 一 更改项目 JDK1 File ProjectStruc Modules 设置 JDK 版本等 2 设定 JDK 编译版本 File Settings compiler

    2025年9月16日
    10
  • GPT-SoVITS项目ONNX模型导出与推理实践指南

    GPT-SoVITS项目ONNX模型导出与推理实践指南

    2026年3月15日
    2
  • 月之暗面完成5亿美元C轮融资

    月之暗面完成5亿美元C轮融资

    2026年3月12日
    1
  • Linux中top命令_linux tail命令详解

    Linux中top命令_linux tail命令详解原标题:Linux下top命令详解1、简介top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。top显示系统当前的进程和其他状况,是一个动态显示过程,可以自动或者通过用户按键来不断刷新当前状态。如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.。比较准确的说,top命令提供了实时的对系统处理器的状态监控,显示系统中CPU…

    2026年3月8日
    7
  • Python 输出百分比的两种方式

    Python 输出百分比的两种方式Python 输出百分比的两种方式注 在 python3 环境下测试 方式 1 直接使用参数格式化 2 2 显示小数点后 2 位显示小数点后 2 位 print percent 2 format 42 50 percent 84 00 不显示小数位 0 即 将 2 改为 0 print percent 0 format 42

    2026年3月20日
    3
  • OMNeT 例程 Tictoc10 学习笔记

    OMNeT 例程 Tictoc10 学习笔记Tictoc10 构建了一个网络 tic 0 首先发送消息 最后 tic 3 收到消息结束 路由效率不高 数据包会在两个节点之间来回传送 方括号 把之前的门变成了门向量 当用 Txc 来建立网络的时候 才决定其向量的大小 门数 gates inputin declarein andout tobevectorga 随机选择一个门发送消息 voidTxc10 forwardMess

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号