dbg调试
一、启动停止dbg
dbg:tracer().
dbg:stop().
二、跟踪常用函数
1、跟踪进程
dbg:p(PidSpec,TraceFlags).
PidSpec
Pid 一个特定进程ID
all 跟踪所有进程
new 跟踪调用调试器之后产生的所有进程
existing 将跟踪调用调试器之前产生的所有进程
alias 一个注册进程的别名,除all、new或者existing之外
{X,Y,Z} 只是由进程ID<X.Y.Z>
TraceFlags
s 跟踪发送消息
r 跟踪接收消息
m 跟踪发送和介绍消息
p 跟踪与进程有关的事件
c 根据dgb:tp/2调用里设定的跟踪模式来跟踪全局和局部调用
sos和sofs 指示set_on_first_spawn标志,我们已经在”继承标志“小结中提到过
sol和sofl 指示set_on_link和set_on_first_link标志,我们已经在”继承标志“小结中提到过
all 设置所有标志
clear 清除所有设定的跟踪标志
例如:
dbg:tracer().
dbg:p(all,[c]).
dbg:stop().
2、跟踪和性能分析函数
dbg:c(io,format,["Hello World!~n"]).
3、跟踪局部和全局函数调用
dbg:tp({Mod,Fun,Arity}, MatchSpec).启动调用跟踪
dbg:ctp({Mod,Fun,Arity}).停止调用跟踪
dbg:tracer().
dbg:p(all,[c]).
dbg:tp({ping,'_','_'},[]).
dbg:ctp({ping,'_','_'}).
dbg:stop().
4、分布式环境
dbg:n(Node).增加一个分布式的ERLANG节点到跟踪列表上,
dbg:cn(Node).删除节点
dbg:ln().列出跟踪的节点
5、重定向输出
dbg:tracer(process,{HandlerFun,Data}).
所有的进程会作为参数传递给HandlerFun,他是用户定义的一个二元fun函数,第一个参数是跟踪信息,第二个是用户定义的Data,函数返回的数据会传给他的下一迭代,类似于累加器。
HandlerFun =
fun({trace,Pid,gc_start,Start}, _) ->
Start;
({trace,Pid,gc_end,End},Start) ->
{_,{_,OHS}} = lists:keysearch(old_heap_size,1,Start),
{_,{_,OHE}} = lists:keysearch(old_heap_size,1,End),
io:format("Old heap size delta after gc:~w~n", [OHS-OHE]),
{_,{_,HS}} = lists:keysearch(heap_size,1,Start),
{_,{_,HE}} = lists:keysearch(heap_size,1,End),
io:format("Heap size delta after gc:~w~n", [HS-HE])
end.
dbg:tracer(process,{HandlerFun,null}).
dbg:p(self(),[garbage_collection]).
List=lists:seq(1,1000).
RevList=lists:reverse(List).
6、重定向套接字和二进制文件
dbg:tracer(port,PortFun).
PortFun 由trace_port(ip,Port).或则trace_port(FileName,Fileoption).的返回值
例如:
节点1
PortFun = dbg:trace_port(ip,1234).
dbg:tracer(port,PortFun).
dbg:p(all,[c]).
dbg:tp({ping,'_','_'},[]).
dbg:tpl({ping,'_','_'},[]).
dbg:ping:start().
ping:send(Pid).
节点2
Pid= dbg:trace_client(ip,1234).
dbg:stop_client(Pid).
7、匹配规则
dbg:fun2ms([Head,Conditions,Body]).
1)head
绑定匹配变量和项元
2)Conditions
逻辑变量应用到项元
3)Body
预处理行为
常用行为
{message,Args} 将Args添加到跟踪事件中。
{return_trace} 函数返回触发跟踪消息发送
{exception_trace} 运行时错误导致所跟踪的函数退出,所残生的跟踪消息
{caller} 返回调用函数
8、存储匹配规则
dbg:tp({io,format,1},[{'_',[],[{message,{process_dump}}]}]).
{ok,[{matched,nonode@nohost,1},{saved,1}]}
{saved1,}存储匹配规则,可以用数字1代替匹配规则本身
dbg:ltp().列出所有匹配规则
dbg:dtp() and dbg:dtp(Id).删除匹配规则
dbg:wtp(FileName).和dbg:rtp(FileName).从一个文件读写匹配规则
9> DbgFun = fun({trace,_Pid,_event,_data,Msg}, _Acc) -> io:format("~s~n",[binary_to_list(Msg)]) end.
#Fun<erl_eval.12.111823515>
10> dbg:tracer(process,{DbgFun,null}).
{ok,<0.51.0>}
11> dbg:tp({io,format,1},[{'_',[],[{message,{process_dump}}]}]).
{ok,[{matched,nonode@nohost,1},{saved,1}]}
12> dbg:p(all,[c]).
{ok,[{matched,nonode@nohost,27}]}
13> io:format("Hello~n").
1> dbg:tracer().
{ok,<0.34.0>}
2> dbg:p(all, c).
{ok,[{matched,nonode@nohost,26}]}
3> dbg:tpl(test, g, dbg:fun2ms(fun(_) -> exception_trace() end)).
{ok,[{matched,nonode@nohost,1},{saved,x}]}
4> dbg:stop(), dbg:stop_clear().
dbg调试的更多相关文章
- linux编译相关命令
一.编译可执行文件 g++ –c Hello.cpp 编译文件,生成目标文件Hello.o g++ Hello.o –o a.out 链接并重命名为可执行文件a.out g++ Hello.cc ...
- JsRender 前端渲染模板常用API学习
JsRender 常用API 1. $.templates() $.templates()方法是用来注册或编译模板的,使用的情况有以下几种. 把html字符串编译编译成模板 获取使用script标签声 ...
- Luogu P2668 斗地主(NOIP2015)
还记得那道我只用特判得了30分的"斗地主"吗? 我今天脑抽打算把它改A掉.为什么不用这大好时光去干些更有意义的事 于是我就挖了这个坑. 题解: 题目链接:P2668 斗地主 本题就 ...
- Apollo安装教程
最近一直在研究Apollo的安装问题,浪费了几天时间,所有特意来记录一下安装心得. UBUNTU 14.04安装 这个我是把自己的笔记本全部转换为ubuntu系统,操作相对简单,大家可以自行查找,另外 ...
- Apollo移植
Apollo移植 环境 平台 ubuntu16.04 Apollo_kernel 1.0 安装步骤步骤 步骤一:安装ubuntu(官方建议使用Ubuntu 14.04.3) 步骤一和步骤二参考文档路径 ...
- C语言入门(21)——使用DBG对C语言进行调试
C语言入门(21)--使用DBG对C语言进行调试 程序中除了一目了然的Bug之外都需要一定的调试手段来分析到底错在哪.到目前为止我们的调试手段只有一种:根据程序执行时的出错现象假设错误原因,然后在代码 ...
- Eclipse断点调试(DBG)Android应用
1.添加断点 双击左侧边框便可添加断点,右击也能添加断点. 2.进入调试模式 点击虫子,然后选择工程运行,快捷键为单击F11 ,如果是正常运行就是Ctrl+F11 3.单步调试+跳到下一个断点 运行到 ...
- ida x32 dbg 动态调试
http://www.xrwcn.com/html/8.html 0x20019u 注册表 RegOpenKeyEx函数 LONG RegOpenKeyEx( HKEY hKey, // handle ...
- (转)利用libcurl和国内著名的两个物联网云端通讯的例程, ubuntu和openwrt下调试成功(四)
1. libcurl 的参考文档如下 CURLOPT_HEADERFUNCTION Pass a pointer to a function that matches the following pr ...
随机推荐
- netty初探(2)
上一篇 netty(1) 一.TCP/IP 流式传输 在上文演示了2进制流式传输引起的TCP拆包问题,这里继续演示文本型的传输问题,文本型的可以有以下几种策略 1.1 以特殊字符表示结尾 HTTP协议 ...
- private set
表示只读: 例:public string DisplayName { get; private set; } 称为"自动属性" 等同于: private string _Dis ...
- Redis性能问题排查解决手册
转自:http://www.cnblogs.com/mushroom/p/4738170.html 阅读目录: 性能相关的数据指标 内存使用率used_memory 命令处理总数total_comma ...
- asp.net MVC Session锁的问题
一直在用Session,对Session锁并没有太多的关注,可能是平时没有注意.前段时间突然发现,一个Ajax Get请求,直接访问地址,只需要几十ms,但是在页面中加载,却需要2s.最后定位到Ses ...
- Maven手动增加依赖jar到本地Maven仓库中
Apache Maven是一个项目管理及自动构建工具,有APache软件基金会提供.我们只要配置成功后就可以通过配置pom.xml添加所需依赖的jar包和类库,因为这些类库已经在我们配置的Maven仓 ...
- 折腾一天,终于配置好了,ssl证书,启用了https,用的阿里云ECS服务器
阿里云ECS服务器配置了ssl证书, httpd-ssl.conf 的配置很重要,网站目录一定要设置正确. 阿里云的虚拟空间,弹性Web,目前好像还不支持ssl证书. 最后要网站强制https,下面 ...
- Windows下怎么搭建Python+Selenium的自动化环境
http://jingyan.baidu.com/article/47a29f244aec6bc014239985.html 注意点:配置了环境变量后需要重启电脑
- RPC框架基本原理(三):调用链路分析
本文主要阐述下RPC调用过程中的寻址,序列化,以及服务端调用问题. 寻址 随机寻址 从可用列表中,随机选择地址 一致性寻址 可用服务地址一致性hash管理:根据可服务的地址,构造treemap,计算c ...
- c# windows服务 一个项目安装多个服务
创建windows服务就不讲解了,其它大神写太多了.这里只写一个项目安装多个服务的教程.如:http://www.cnblogs.com/zzgblog/p/4595839.html 首先按下图创建多 ...
- Linux服务器操作系统
Linux服务器操作系统 今日大纲 ● 服务器操作系统的系列.Linux的主流产品.虚拟机软件 ● 安装linux ● linux基本命令 ● 用户管理及权限(多用户) ● ...