写了一个 go 的异步 log 组件。为了保障异步的 channel 被彻底消费完,我增加了Exit()
函数,但我想让调用无感知,不用刻意去调用这个函数。有没有什么办法或方式能够实现?
package main import ( "os" "github.com/ml444/glog" ) func main() { // doing something log.Info("hello world") // doing something _ = log.Exit()
1 0o0O0o0O0o 2022-10-23 14:53:42 +08:00 via iPhone 不能,一般用 defer 吧 defer log.Exit() |
![]() | 2 VANHOR 2022-10-23 14:58:43 +08:00 确实得有一个地方来判断 channel 是否被消耗完了,所以还是得写上的。 |
![]() | 3 iyaozhen 2022-10-23 15:09:47 +08:00 理论上不能,所以很多时候需要在 main.go 加个 defer log.flush |
4 securityCoding 2022-10-23 17:25:36 +08:00 via Android 可以在 new 方法内部,启动一个协程监听系统退出信号调用 exit |
![]() | 5 Morriaty 2022-10-23 18:00:30 +08:00 官方做法是 sync.WaitGroup ,主要三个函数 group.Add(1) 每进入一个协程加一次计数 defer group.Done() 协程结束标志,计数减一 group.Wait() 等待计数清零,约等于你这里的 log.Exit() |
![]() | 6 fuis 2022-10-23 18:56:13 +08:00 |
7 jackliang007 2022-10-24 00:01:35 +08:00 via iPhone 日志全部发送到消息队列,然后用开个协程来处理。 |
8 bugfan 2022-10-24 01:15:00 +08:00 4 楼正解 |
9 ml444 OP @securityCoding 没用哦,我试过 panic 时,是收不到信号的 |
10 securityCoding 2022-11-04 18:16:07 +08:00 业务协程 panic 要他自己兜底 ,跟你的日志组件有啥关系? |
11 ml444 OP @securityCoding panic 会导致异步日志丢失,所以我问的是有什么方式能够保障 panic 这种异常故障的时候,让日志能够写完再退出 |
12 securityCoding 2022-11-04 18:51:39 +08:00 via Android @ml444 没理解你的意思,一般框架层都会做 recover 兜底,同时日志组件也需要定时 flush |
13 securityCoding 2022-11-04 18:53:45 +08:00 via Android @ml444 刷盘思路可以看下 zap 或者 gozero log |