swaminathanmanish commented on code in PR #14742: URL: https://github.com/apache/pinot/pull/14742#discussion_r1905235376
########## pinot-plugins/pinot-minion-tasks/pinot-minion-builtin-tasks/src/main/java/org/apache/pinot/plugin/minion/tasks/upsertcompactmerge/UpsertCompactMergeTaskGenerator.java: ########## @@ -296,18 +317,22 @@ public static SegmentSelectionResult processValidDocIdsMetadata(Map<String, Stri // variables to maintain current group sum long currentValidDocsSum = 0; long currentTotalDocsSum = 0; + double currentOutputSegmentSizeInBytes = 0.0; for (SegmentMergerMetadata segment : segments) { long validDocs = segment.getValidDocIds(); long invalidDocs = segment.getInvalidDocIds(); + double expectedSegmentSizeInBytes = segment.getSegmentSizeInBytes(); // Check if adding this segment would keep the validDocs sum within the threshold if (currentValidDocsSum + validDocs <= validDocsThreshold && currentGroup.size() < maxNumSegments - && currentTotalDocsSum + validDocs + invalidDocs < maxRecordsPerTask) { + && currentTotalDocsSum + validDocs + invalidDocs < maxRecordsPerTask + && currentOutputSegmentSizeInBytes + expectedSegmentSizeInBytes < outputSegmentMaxSizeInBytes) { // Add the segment to the current group currentGroup.add(segment); currentValidDocsSum += validDocs; currentTotalDocsSum += validDocs + invalidDocs; + currentOutputSegmentSizeInBytes += expectedSegmentSizeInBytes; Review Comment: Thanks @tibrewalpratik17 . By default do we want to have 200Mb segments? This changes the default segment size and can overide maxNumRecordsPerSegment. We can make the new param opt-in and not apply default? && currentTotalDocsSum + validDocs + invalidDocs < maxRecordsPerTask && currentOutputSegmentSizeInBytes + expectedSegmentSizeInBytes < outputSegmentMaxSizeInBytes) { -- 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: commits-unsubscr...@pinot.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org --------------------------------------------------------------------- To unsubscribe, e-mail: commits-unsubscr...@pinot.apache.org For additional commands, e-mail: commits-h...@pinot.apache.org