stevenzwu commented on code in PR #9308:
URL: https://github.com/apache/iceberg/pull/9308#discussion_r1431726956


##########
flink/v1.18/flink/src/main/java/org/apache/iceberg/flink/source/reader/IcebergSourceSplitReader.java:
##########
@@ -80,6 +88,35 @@ public RecordsWithSplitIds<RecordAndPosition<T>> fetch() 
throws IOException {
     }
 
     if (currentReader.hasNext()) {
+      if (pausedSplits.contains(currentSplitId)) {
+        // Wait until the reader is unblocked. Wake every second to catch any 
missed signal.
+        // Return empty records if wakeUp is called, so pauseOrResumeSplits 
could be processed.
+        boolean first = true;

Review Comment:
   @pvary I am fine with while-loop and using wait timeout. I understand it is 
safer for avoiding potential deadlock.
   
   > The main issue is that the wakeUp and the pauseOrResumeSplits is not 
atomic, we need another flag to store if the given wakeUp is handled, or not.
   
   I see the problem now from the timeline example you said earlier.



-- 
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: issues-unsubscr...@iceberg.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: issues-unsubscr...@iceberg.apache.org
For additional commands, e-mail: issues-h...@iceberg.apache.org

Reply via email to