mosche commented on a change in pull request #15955:
URL: https://github.com/apache/beam/pull/15955#discussion_r757580717



##########
File path: 
sdks/java/io/kinesis/src/main/java/org/apache/beam/sdk/io/kinesis/KinesisIO.java
##########
@@ -1067,8 +1063,11 @@ private void checkForFailures(String message) throws 
IOException {
 
       @Teardown
       public void teardown() throws Exception {
-        if (producer != null && producer.getOutstandingRecordsCount() > 0) {
-          producer.flushSync();
+        if (producer != null) {
+          if (producer.getOutstandingRecordsCount() > 0) {
+            producer.flushSync();
+          }
+          producer.destroy();
         }
         producer = null;

Review comment:
       Finally getting back to this. I think the reason this worked is 
`producer.flushSync()`. With that a busy producer likely won't get destroyed. 
Really sketchy ...
   ```
       public void flushSync() {
           while (getOutstandingRecordsCount() > 0) {
               flush();
               try {
                   Thread.sleep(500);
               } catch (InterruptedException e) { }
           }
       }
       ```




-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


Reply via email to