当我生成消息时,我正在使用用 Go 编写的 Sarama 库从错误通道中读取。整个代码如下所示,包含在一个函数中:
producer.AsyncProducer.Input() <- &sarama.ProducerMessage{Topic: topic, Key: nil, Value: sarama.ByteEncoder(message)}
go func() {
for err := range saramaProducer.Errors() {
if producer.callbacks.OnError != nil {
producer.callbacks.OnError(err)
}
}
}()
正如我对 goroutines 的理解一样,我的 goroutines 会在通道上不断迭代,Errors()
直到它收到一个。一旦我的函数执行完毕,有没有办法让它停止监听错误?