如果我想go程序在产生panic导致程序core时,统一去刷新日志后程序再退出,要怎么实现呢?
之前c++程序是可以去捕捉core时产生的信号来进行这些处理,使用go也尝试使用这种方式,设置export GOTRACEBACK=crash的环境变量,并且捕捉信号进行处理,但是试了下会产生core文件,但是捕捉不到信号。
现在的处理方式是在所有的携程函数中定义一个defer 去进行这些刷日志操作,当携程panic导致core或者正常退出时都会去刷日志这个操作,基本也能满足需求,但是需要在每个携程里面写defer去干这个事情,感觉比较麻烦。
所以在这里请教下大神们有没有更好的处理方式,在程序core时去做一些特殊的操作,谢谢
写了个简单的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
更多评论
是没有捕捉到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