Golang panic 打印堆栈信息

一. 缘起

  • 程序进程后台运行
  • monitor 监控程序负责拉起程序

当因为逻辑问题导致后台进程挂掉时,不容易发现程序曾经挂过。

golang 可以通过 recover 捕获 error,并将 panic 时的堆栈打印到日志来定位问题。

$ tree panictest
panictest
├── main.go
└── panic
    └── panic.go

二. 代码

main.go

package main

import (
    "fmt"
    "os"

    "./panic"
)

func test() {
    defer func() {
        if e := recover(); e != nil {
            panic.PrintStack()
            os.Exit(1)
        }
    }()

    zero := 0
    x := 3 / zero
    fmt.Println("x=", x)
}

func main() {
    test()
}

panic.go

package panic

import (
    "fmt"
    "runtime"
)

func PrintStack() {
    var buf [4096]byte
    n := runtime.Stack(buf[:], false)
    fmt.Printf("==> %s\n", string(buf[:n]))
}

三. 运行结果

$ go run main.go 
==> goroutine 1 [running]:
_/tmp/panictest/panic.PrintStack()
    /tmp/panictest/panic/panic.go:10 +0x5b
main.test.func1()
    /tmp/panictest/main.go:13 +0x44
panic(0x49c640, 0x525390)
    /usr/local/go/src/runtime/panic.go:505 +0x229
main.test()
    /tmp/panictest/main.go:19 +0x3e
main.main()
    /tmp/panictest/main.go:24 +0x20

exit status 1

能够看出问题出在main.go:19x := 3 / zero这一行。

可以将fmt.Println替换成你的日志输出函数。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值