是否可以推迟goroutine?

时间:2016-10-06 14:51:39

标签: go deferred goroutine

是否有可能推迟一个go例程,或者一种方法来实现所期望的行为?以下背景:我正在汇集到通道中数据库的连接。基本上在我称之为

的处理程序中
session, err := getSessionFromQueue()
// ...
// serving content to my client
// ...
go queueSession(session)

我真正想做的是:

session, err := getSessionFromQueue()
defer go queueSession(session)
// ...
// serving content to my client
// ...

以避免我的处理程序在某个时刻挂起/崩溃并且会话未正确返回到队列。我想将它作为go例程运行的原因是queueSession可能会阻塞1秒(如果队列已满,我会在完全关闭会话之前等待一秒钟。)

更新

@abhink让我走在正确的轨道上。我通过在queueBackend中调用goroutine解决了这个问题。

func queueSession(mongoServer *Server) {
    go func(mongoServer *Server) {
        select {
        case mongoQueue <- mongoServer:
            // mongoServer stored in queue, done.
        case <- time.After(1 * time.Second):
            // cannot queue for whatever reason after 1 second
            // abort
            mongoServer.Close()
        }
    }(mongoServer)
}

现在我可以简单地致电

defer queueSession(session)

它以goroutine的形式运行。

1 个答案:

答案 0 :(得分:11)

没有办法直接defer goroutine。你可以尝试这样的事情:

session, err := getSessionFromQueue()
defer func() {
    go queueSession(session)
}()