V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
ml444

go 中,进程退出如何保障异步协程的完整退出。

  •  
  •   ml444 · Oct 23, 2022 · 3037 views
    This topic created in 1282 days ago, the information mentioned may be changed or developed.

    写了一个 go 的异步 log 组件。为了保障异步的 channel 被彻底消费完,我增加了Exit()函数,但我想让调用无感知,不用刻意去调用这个函数。有没有什么办法或方式能够实现?

    package main
    
    import (
    	"os"
    	
    	"github.com/ml444/glog"
    )
    
    func main() {
    	// doing something
    	log.Info("hello world")
    	// doing something
    
    	_ = log.Exit()
    
    13 replies    2022-11-04 18:53:45 +08:00
    0o0O0o0O0o
        1
    0o0O0o0O0o  
       Oct 23, 2022 via iPhone
    不能,一般用 defer 吧

    defer log.Exit()
    VANHOR
        2
    VANHOR  
       Oct 23, 2022
    确实得有一个地方来判断 channel 是否被消耗完了,所以还是得写上的。
    iyaozhen
        3
    iyaozhen  
       Oct 23, 2022
    理论上不能,所以很多时候需要在 main.go 加个 defer log.flush
    securityCoding
        4
    securityCoding  
       Oct 23, 2022 via Android
    可以在 new 方法内部,启动一个协程监听系统退出信号调用 exit
    Morriaty
        5
    Morriaty  
       Oct 23, 2022
    官方做法是 sync.WaitGroup ,主要三个函数

    group.Add(1) 每进入一个协程加一次计数
    defer group.Done() 协程结束标志,计数减一
    group.Wait() 等待计数清零,约等于你这里的 log.Exit()
    jackliang007
        7
    jackliang007  
       Oct 24, 2022 via iPhone
    日志全部发送到消息队列,然后用开个协程来处理。😄
    bugfan
        8
    bugfan  
       Oct 24, 2022
    4 楼正解
    ml444
        9
    ml444  
    OP
       Nov 4, 2022
    @securityCoding 没用哦,我试过 panic 时,是收不到信号的
    securityCoding
        10
    securityCoding  
       Nov 4, 2022
    业务协程 panic 要他自己兜底 ,跟你的日志组件有啥关系?
    ml444
        11
    ml444  
    OP
       Nov 4, 2022
    @securityCoding panic 会导致异步日志丢失,所以我问的是有什么方式能够保障 panic 这种异常故障的时候,让日志能够写完再退出
    securityCoding
        12
    securityCoding  
       Nov 4, 2022 via Android
    @ml444 没理解你的意思,一般框架层都会做 recover 兜底,同时日志组件也需要定时 flush
    securityCoding
        13
    securityCoding  
       Nov 4, 2022 via Android
    @ml444 刷盘思路可以看下 zap 或者 gozero log
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3868 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 49ms · UTC 00:46 · PVG 08:46 · LAX 17:46 · JFK 20:46
    ♥ Do have faith in what you're doing.