热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

erlang问题定位利器recon_trace

闲聊几句用erlang有1年有余,也是第一次接触函数式编程,主要用于编写性能测试工具,在使用初期问题较少,遇到问题我仍习惯性通过debug来解决,勉强能用,但是随着系统复杂性增加,

闲聊几句

用erlang有1年有余,也是第一次接触函数式编程,主要用于编写性能测试工具,在使用初期问题较少,遇到问题我仍习惯性通过debug来解决,勉强能用,但是随着系统复杂性增加,多线程运行时debug就显得难上加难,这是和之前面向过程编程有本质区别。

之后结识了dbg trace,很强大的工具,可以很方便地分析系统执行过程中的情况,但是相比较而言我会更推荐recon_trace这个工具,该工具是程序员里漫画画的最好的Fred写的,同时也是<>的作者。

初识recon_trace

recon_trace绝对是协助你定位线上问题的一把利器,目前只支持trace函数调用,基本够用了。工具基于erlang:trace进行了二次封装,特性如下:

  • 调用更友好,比起dbg:trace()和erlang:trace()更好用
  • 防止用户trace信息过多引起系统崩溃,比如trace当前节点所有进程的函数调用信息
  • 提供maxcount,maxfre参数,防止flooding
  • 输出信息格式优化

小试牛刀

先来试试trace 任意进程对queue:new的调用

注意最后那个参数,1就是maxcount参数,它决定了最多trace信息的数量,防止tracce flooding。

1> recon_trace:calls({queue, new, ‘_’}, 1).
1
2> queue:new().
{[],[]}
3>
22:26:54.646000 <0.55.0> queue:new()
3> Recon tracer rate limit tripped.
3>

返回值去哪了

我们如果想获取调用函数的返回值需要return_trace的帮助,如下:

6> recon_trace:calls({queue, new, fun(_) -> return_trace() end}, 2).
1
7> queue:new().

22:45:09.098000 <0.55.0> queue:new()

22:45:09.098000 <0.55.0> queue:new/0 –> {[],[]}
{[],[]}
Recon tracer rate limit tripped.

本实例中除了return_trace需要添加外,maxcount的数量你也可以尝试改为1,试试看,你会对maxcount有更深的认识

来个更复杂的

when语句限定了只trace属于queue模块的函数的调用,且第一个函数参数为列表或第一个参数为大于1的数字。另外请注意最后一个tuple参数,这个参数可以理解为maxfreq,即trace信息的最大频率,{10,100}表示100毫秒内做多打印10条trace信息。这算是防止flooding的另外一种策略。

recon_trace:calls(
      {queue, '__', fun([A,_]) when is_list(A); is_integer(A) andalso A > 1 -> return_trace() end},
      {10,100}
).

如何限定调用pid

有时我们只关注发生在特定进程的调用,那么就需要calls/3,在第三个参数可以指定附加参数信息,还有其他附加参数,这里不一一列出,可以看官方文档,或者索性直接源码。

recon_trace:calls({queue, '_', '_'}, {50,1000}, [{pid, Pid}])

如何停止trace

recon_trace:clear()


推荐阅读
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • JUC(三):深入解析AQS
    本文详细介绍了Java并发工具包中的核心类AQS(AbstractQueuedSynchronizer),包括其基本概念、数据结构、源码分析及核心方法的实现。 ... [详细]
  • 双指针法在链表问题中应用广泛,能够高效解决多种经典问题,如合并两个有序链表、合并多个有序链表、查找倒数第k个节点等。本文将详细介绍这些应用场景及其解决方案。 ... [详细]
  • 一篇关于五个编程问题的 Reddit 帖子引发了广泛讨论,特别是关于这些题目是否适合所有软件工程师。 ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 阿里巴巴终面技术挑战:如何利用 UDP 实现 TCP 功能?
    在阿里巴巴的技术面试中,技术总监曾提出一道关于如何利用 UDP 实现 TCP 功能的问题。当时回答得不够理想,因此事后进行了详细总结。通过与总监的进一步交流,了解到这是一道常见的阿里面试题。面试官的主要目的是考察应聘者对 UDP 和 TCP 在原理上的差异的理解,以及如何通过 UDP 实现类似 TCP 的可靠传输机制。 ... [详细]
  • Python多线程编程技巧与实战应用详解 ... [详细]
  • 深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案
    深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 如何撰写适应变化的高效代码:策略与实践
    编写高质量且适应变化的代码是每位程序员的追求。优质代码的关键在于其可维护性和可扩展性。本文将从面向对象编程的角度出发,探讨实现这一目标的具体策略与实践方法,帮助开发者提升代码效率和灵活性。 ... [详细]
  • 如何撰写初级和高级前端开发者的专业简历
    如何撰写初级和高级前端开发者的专业简历 ... [详细]
  • 开发日志:201521044091 《Java编程基础》第11周学习心得与总结
    开发日志:201521044091 《Java编程基础》第11周学习心得与总结 ... [详细]
author-avatar
手机用户2502873667
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有