询问一个关于 golang经常自动重启

ccoding · · 2063 次点击
jan-bar
想要拥有,必定付出。
神奇的现象,我遇到所有go程序重启都会有panic打印,很快就能发现问题。难道说你这个程序时操作系统杀死,go进程内部还没来得急出现panic逻辑么?我觉得你可以捕获一些常用的信号,捕获成功加上打印试试。只要不是`kill -9 pid`这种信号,都可以捕获成功吧。
#11
更多评论
在容易出错的地方要加上容错的机制,使用panic recover机制抓住错误信息就可以定位问题在哪里,然后再解决问题。 个人觉得常出错的地方有使用了nil的数据、数组越界了是最常见的,另外还有一些不容易发现的比如没有关闭链接之类的。 最好是能上源码,如果不关乎行业机密的话。
#1
panic 在日志里没有发现,有,我写个伪代码吧 ```golang func main() { for { conn, e := ln.Accept() if e != nil { if ne, ok := e.(net.Error); ok && ne.Temporary() { logger.Init("异常").Info("接收错误信息:%v" + fmt.Sprintf("accept temp err: %v", ne)) continue } } // 解析连接消息 路由模式开启 go goHandleConn(conn) } } func goHandleConn(conn net.Conn) { defer func() { if conn != nil { conn.Close() } if err := recover(); err != nil { //获取程序名称 appExeName := os.Args[0] pid := os.Getegid() logger.Init("POSP中台").Error("goHandleConn:引发panic异常", zap.Reflect("error", err), zap.Reflect("app", appExeName), zap.Reflect("pid", pid), zap.Reflect("strack", string(debug.Stack())), zap.Reflect("LogId", logId), ) notice.NoticeMsg("goHandleConn:引发panic异常", fmt.Sprintf("LogId:%s %v:app:%v:pid:%v:strack:", logId, err, appExeName, pid, string(debug.Stack()))) } return }() // todo 查询数据库 这个地方用到gorm _, err = conn.Write(recBuf) return } ```
#2