1. 首页
  2. 主题
  3. Go基础

go程序panic导致core时的处理问题

highfly43 · · 2629 次点击
如果我想go程序在产生panic导致程序core时,统一去刷新日志后程序再退出,要怎么实现呢? 之前c++程序是可以去捕捉core时产生的信号来进行这些处理,使用go也尝试使用这种方式,设置export GOTRACEBACK=crash的环境变量,并且捕捉信号进行处理,但是试了下会产生core文件,但是捕捉不到信号。 现在的处理方式是在所有的携程函数中定义一个defer 去进行这些刷日志操作,当携程panic导致core或者正常退出时都会去刷日志这个操作,基本也能满足需求,但是需要在每个携程里面写defer去干这个事情,感觉比较麻烦。 所以在这里请教下大神们有没有更好的处理方式,在程序core时去做一些特殊的操作,谢谢
捕获不到 SIGABRT 信号?
#1
更多评论
是没有捕捉到SIGABRT信号。 信号是通过以下方式捕捉的: ```go c := make(chan os.Signal) defer close(c) signal.Notify(c) for { sig := <-c log.LOG_INFO_F("recv sig :%v", sig) } ``` 不知道是不是我的信号捕捉有问题。
#2
写了个简单的demo: ```go package main import ( "fmt" "os" "os/signal" "time" ) func dealSignal() { sigChan := make(chan os.Signal) defer close(sigChan) signal.Notify(sigChan) for { sig := <-sigChan fmt.Println("recv sig :", sig) } } func coreFunc() { var mapCore map[int]int //此处会panic mapCore[0] = 1 } func main() { go dealSignal() time.Sleep(3 * time.Second) go coreFunc() time.Sleep(3 * time.Second) } ```
#3

用户登录

没有账号?注册

今日阅读排行

    加载中

一周阅读排行

    加载中