From 2c8f217ce43062e88316d4136262c4f66767d2b2 Mon Sep 17 00:00:00 2001 From: Lambert Date: Mon, 30 Aug 2021 21:49:59 +0900 Subject: [PATCH] docs: update AsyncProducer Close pitfalls --- async_producer.go | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/async_producer.go b/async_producer.go index 5911f7b58..8de7c7fc0 100644 --- a/async_producer.go +++ b/async_producer.go @@ -14,8 +14,8 @@ import ( // to the correct broker for the provided topic-partition, refreshing metadata as appropriate, // and parses responses for errors. You must read from the Errors() channel or the // producer will deadlock. You must call Close() or AsyncClose() on a producer to avoid -// leaks: it will not be garbage-collected automatically when it passes out of -// scope. +// leaks and message lost: it will not be garbage-collected automatically when it passes +// out of scope and buffered messages may not be flushed. type AsyncProducer interface { // AsyncClose triggers a shutdown of the producer. The shutdown has completed @@ -26,7 +26,8 @@ type AsyncProducer interface { // Close shuts down the producer and waits for any buffered messages to be // flushed. You must call this function before a producer object passes out of - // scope, as it may otherwise leak memory. You must call this before calling + // scope, as it may otherwise leak memory. You must call this before process + // shutting down, or you may lose messages. You must call this before calling // Close on the underlying client. Close() error