This is an automated email from the ASF dual-hosted git repository.

nicholasjiang pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/celeborn.git


The following commit(s) were added to refs/heads/main by this push:
     new 77a892164 [CELEBORN-2212] Optimize the sorting efficiency of 
memoryWriters when evicting the largest memory file
77a892164 is described below

commit 77a8921648c77a6fd073a09e07aa6f41a98153c1
Author: xxx <[email protected]>
AuthorDate: Thu Dec 11 13:21:47 2025 +0800

    [CELEBORN-2212] Optimize the sorting efficiency of memoryWriters when 
evicting the largest memory file
    
    ### What changes were proposed in this pull request?
    
    Optimize the sorting efficiency of memoryWriters when evicting the largest 
memory file.
    
    ### Why are the changes needed?
    
    Optimize the sorting efficiency of memoryWriters when evicting the largest 
memory file.
    
    ### Does this PR resolve a correctness bug?
    
    No.
    
    ### Does this PR introduce _any_ user-facing change?
    
    No.
    
    ### How was this patch tested?
    
    CI.
    
    Closes #3549 from xy2953396112/CELEBORN-2212.
    
    Authored-by: xxx <[email protected]>
    Signed-off-by: SteNicholas <[email protected]>
---
 .../apache/celeborn/service/deploy/worker/memory/MemoryManager.java  | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git 
a/worker/src/main/java/org/apache/celeborn/service/deploy/worker/memory/MemoryManager.java
 
b/worker/src/main/java/org/apache/celeborn/service/deploy/worker/memory/MemoryManager.java
index 4920a5ce4..dde5793c5 100644
--- 
a/worker/src/main/java/org/apache/celeborn/service/deploy/worker/memory/MemoryManager.java
+++ 
b/worker/src/main/java/org/apache/celeborn/service/deploy/worker/memory/MemoryManager.java
@@ -257,8 +257,9 @@ public class MemoryManager {
                 logger.info("Start evicting {} memory file infos", 
memoryWriters.size());
                 // always evict the largest memory file info first
                 memoryWriters.sort(
-                    Comparator.comparingLong(o -> 
o.getMemoryFileInfo().getFileLength()));
-                Collections.reverse(memoryWriters);
+                    Comparator.comparingLong(
+                            (PartitionDataWriter o) -> 
o.getMemoryFileInfo().getFileLength())
+                        .reversed());
                 for (PartitionDataWriter writer : memoryWriters) {
                   // this branch means that there is no memory pressure
                   if (!shouldEvict(aggressiveEvictModeEnabled, evictRatio)) {

Reply via email to