V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
fengjianxinghun
V2EX  ›  Go 编程语言

go 编译成 c shared 库使用 luaffi load 会死锁

  •  
  •   fengjianxinghun · 2019-05-27 18:17:31 +08:00 · 3266 次点击
    这是一个创建于 2037 天前的主题,其中的信息可能已经有所发展或是发生改变。

    export go 函数然后编译成 c 动态库,这里完美注意了 cgo 的内存搬运问题。

    go build -o iface.so -buildmode=c-shared -ldflags "-w -s" iface.go
    

    然后在 OpenResty 下用 luaffi load 这个动态库,平时使用没什么问题。最近发现在 reload 比较频繁下会偶发 reload 卡住。

    上去用 gdb -p <nginx master="" pid=""></nginx>

    bt 当前栈顶在这个 go 动态库中,由于没有调试符号,只能反汇编。

    diss/r $rip,查看 syscall 前的 rax 值,发现当前 master 阻塞在 futex syscall 上,发生了死锁。

    4 条回复    2019-05-28 12:27:09 +08:00
    kofj
        1
    kofj  
       2019-05-27 22:12:32 +08:00
    还能这么玩儿,mark 一下
    chennqqi
        2
    chennqqi  
       2019-05-28 09:42:01 +08:00
    把 -ldflags "-w -s" 去掉就有符号了,挂上去调试吧
    icexin
        3
    icexin  
       2019-05-28 11:53:51 +08:00
    fork+多线程会有很多 bug
    juzipeek
        4
    juzipeek  
       2019-05-28 12:27:09 +08:00
    reload 时动态是否有变化,如果有变化容易出现问题
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   987 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 22:00 · PVG 06:00 · LAX 14:00 · JFK 17:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.