lldb 调试electron渲染进程下的插件

写在前面

提问:最好的debug方式是什么?
正确答案: console.log, print, std::cout <<, System.out.println (狗头)

lldb是一个macos默认使用的一个调试器, LLDB 能够逐行调试程序,使开发者能够了解程序的变量值以及堆栈是如何变化的

这个东西同样可以用来调试nodejs的原生插件,就是.node后缀的那些文件,node的原生插件是可以用不止c/c++语言编辑并编译出的动态链接库,类似.lib, .dylib等等,lldb可以调试他;

既然能够调试node插件,那运行在electron环境下的node插件肯定也是可以调试的啦

首先把调试的部分代码拿出来看看

struct Wdw {
  std::string name;
  size_t age;
};

inline void error(const std::string& s) {
  throw std::runtime_error(s);
}

Napi::Value WdwAdd(const Napi::CallbackInfo& info) {
  Napi::Env env = info.Env();

  if (info.Length() < 2) {
    Napi::TypeError::New(env, "Wrong number of arguments")
        .ThrowAsJavaScriptException();
    return env.Null();
  }
  if (!info[0].IsNumber() || !info[1].IsNumber()) {
    Napi::TypeError::New(env, "Wrong arguments").ThrowAsJavaScriptException();
    return env.Null();
  }
  Wdw wdw;
  wdw.name = "wdw";
  wdw.age = 22;

  double arg0 = info[0].As<Napi::Number>().DoubleValue();
  double arg1 = info[1].As<Napi::Number>().DoubleValue();

  if (arg0 > 5) {
    error("How dare you!");
  }
  Napi::Number num = Napi::Number::New(env, arg0 + arg1 + wdw.age);

  return num;
}

第一步:编译一个debug版本的electron

关于安装可以查看这篇文章

第二步:使用Electron启动你的应用

在官方工具里就是用命令e start ‘path/to/your/main.js’即可

第三步:挂载lldb到渲染进程

这里需要获取到渲染进程的PID, 我直接在渲染进程里调用console.log(process.pid)就有了,然后使用lldb -p PID就可以挂载成功了,其他的还有通过进程名称挂载等多种方式,去看官方文档

第四步:开始调试

(lldb) continue 首先我们挂载成功后程序会挂起,continue可以让程序继续执行

(lldb) continue
Process 43555 resuming

(lldb) breakpoint set -n WdwAdd 我们添加一个断点,这个断点就是名称为WdwAdd的函数,如果怕同样的名称太多的话可以添加-s(--shlib)限定指定文件下,比如-s addon.node限定在这个文件下

(lldb) breakpoint set -n WdwAdd -s addon.node
Breakpoint 1: where = addon.node`WdwAdd(Napi::CallbackInfo const&) + 15 at addon.cc:9:19, address = 0x0000000105cbddff

然后我们正常运行代码,让代码执行到我们打了断点的位置

Process 43555 stopped
* thread #1, name = 'CrRendererMain', queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    frame #0: 0x0000000105cbddff addon.node`WdwAdd(info=0x00007ff7ba7d06d0) at addon.cc:9:19
   6    };
   7    
   8    Napi::Value WdwAdd(const Napi::CallbackInfo& info) {
-> 9      Napi::Env env = info.Env();
   10   
   11     if (info.Length() < 2) {
   12       Napi::TypeError::New(env, "Wrong number of arguments")
Target 0: (Electron Helper (Renderer)) stopped.

这里能看到我们已经进入到代码里了,停在方法开头,然后我们可以用next命令来走下一步,相似的命令还有thread step-in/step-over/step-out

假如我们走下一步走到了这个位置

Process 95183 stopped
* thread #1, name = 'CrRendererMain', queue = 'com.apple.main-thread', stop reason = step over
    frame #0: 0x0000000105cbdf3a addon.node`WdwAdd(info=0x00007ff7ba7d06d0) at addon.cc:21:12
   18       return env.Null();
   19     }
   20     Wdw wdw;
-> 21     wdw.name = "wdw";
   22     wdw.age = 22;
   23   
   24     double arg0 = info[0].As<Napi::Number>().DoubleValue();
Target 0: (Electron Helper (Renderer)) stopped.

然后我们想查看wdw这个对象,就可以使用print wdw或者frame variable wdw来打印wdw

(lldb) print wdw
(Wdw) $10 = (name = "", age = 140659125325832)

查crash位置

在生产环境中遇到crash的问题,我们很难定位到问题到底出在哪里,如果我们有复现路径的话,那我们就可以很方便的用lldb查到准确的crash位置

在挂载命令那里添加一个选项

lldb -p PID -o ’backtrace‘
-o
   --one-line
        Tells the debugger to execute this one-line lldb command after any
        file provided on the command line has been loaded.

这样在程序运行crash的时候,他会先停下来,运行backtrace,这个命令就打打印frames栈,你就能看到crash的位置

(lldb) backtrace
* thread #1, name = 'CrRendererMain', queue = 'com.apple.main-thread', stop reason = signal SIGABRT
  * frame #0: 0x00007ff81177b00e libsystem_kernel.dylib`__pthread_kill + 10
    frame #1: 0x00007ff8117b11ff libsystem_pthread.dylib`pthread_kill + 263
    frame #2: 0x00007ff8116fcd24 libsystem_c.dylib`abort + 123
    frame #3: 0x00007ff81176d082 libc++abi.dylib`abort_message + 241
    frame #4: 0x00007ff81175e1a5 libc++abi.dylib`demangling_terminate_handler() + 242
    frame #5: 0x00007ff81165ae19 libobjc.A.dylib`_objc_terminate() + 104
    frame #6: 0x00007ff81176c4a7 libc++abi.dylib`std::__terminate(void (*)()) + 8
    frame #7: 0x00007ff81176ed05 libc++abi.dylib`__cxxabiv1::failed_throw(__cxxabiv1::__cxa_exception*) + 27
    frame #8: 0x00007ff81176eccc libc++abi.dylib`__cxa_throw + 116
    frame #9: 0x00000001052c8765 addon.node`error(s="How dare you!") at addon.cc:9:3
    frame #10: 0x00000001052c8147 addon.node`WdwAdd(info=0x00007ff7bb1ce6d0) at addon.cc:32:5
    frame #11: 0x0000000108eef4ef ZegoExpressNodeNative.node`napi_value__* Napi::details::WrapCallback<Napi::details::CallbackData<Napi::Value (*)(Napi::CallbackInfo const&), Napi::Value>::Wrapper(napi_env__*, napi_callback_info__*)::'lambda'()>(Napi::details::CallbackData<Napi::Value (*)(Napi::CallbackInfo const&), Napi::Value>::Wrapper(napi_env__*, napi_callback_info__*)::'lambda'()) + 47
    frame #12: 0x0000000108eef48d ZegoExpressNodeNative.node`Napi::details::CallbackData<Napi::Value (*)(Napi::CallbackInfo const&), Napi::Value>::Wrapper(napi_env__*, napi_callback_info__*) + 29

可以看到在我们的程序addon.node的文件9行的位置抛出了异常

链接

https://lldb.llvm.org/status/goals.html
https://medium.com/@ahmedsulaiman/debugging-swift-code-with-lldb-b30c5cf2fd49

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容