是否有可能推迟一个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的形式运行。
答案 0 :(得分:11)
没有办法直接defer
goroutine。你可以尝试这样的事情:
session, err := getSessionFromQueue()
defer func() {
go queueSession(session)
}()