- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2.3k
Writable warm replica replication/recovery #17390
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Writable warm replica replication/recovery #17390
Conversation
| ❌ Gradle check result for 6fde641: FAILURE Please examine the workflow log, locate, and copy-paste the failure(s) below, then iterate to green. Is the failure a flaky test unrelated to your change? | 
        
          
                server/src/main/java/org/opensearch/index/engine/NRTReplicationEngine.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/cluster/routing/allocation/IndexMetadataUpdater.java
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/indices/replication/SegmentReplicationTarget.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/index/store/remote/utils/cache/SegmentedCache.java
          
            Show resolved
            Hide resolved
        
      719a67d    to
    1963b58      
    Compare
  
            
          
                server/src/main/java/org/opensearch/index/engine/NRTReplicationEngine.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
      | ❌ Gradle check result for 1963b58: FAILURE Please examine the workflow log, locate, and copy-paste the failure(s) below, then iterate to green. Is the failure a flaky test unrelated to your change? | 
1963b58    to
    3ce8970      
    Compare
  
    | ❌ Gradle check result for 3ce8970: FAILURE Please examine the workflow log, locate, and copy-paste the failure(s) below, then iterate to green. Is the failure a flaky test unrelated to your change? | 
3ce8970    to
    505a59c      
    Compare
  
            
          
                server/src/main/java/org/opensearch/index/store/remote/utils/FileTypeUtils.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/index/store/CompositeDirectory.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/index/store/CompositeDirectory.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/index/store/CompositeDirectory.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/index/store/CompositeDirectory.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/test/java/org/opensearch/index/store/CompositeDirectoryTests.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                server/src/main/java/org/opensearch/indices/replication/SegmentReplicationTarget.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
      8339c0f    to
    cf1b64b      
    Compare
  
    | ❌ Gradle check result for cf1b64b: FAILURE Please examine the workflow log, locate, and copy-paste the failure(s) below, then iterate to green. Is the failure a flaky test unrelated to your change? | 
cf1b64b    to
    d920d71      
    Compare
  
    | ❌ Gradle check result for d920d71: FAILURE Please examine the workflow log, locate, and copy-paste the failure(s) below, then iterate to green. Is the failure a flaky test unrelated to your change? | 
d920d71    to
    17b43da      
    Compare
  
    Signed-off-by: Sandeep Kumawat <skumwt@amazon.com>
        
          
                server/src/main/java/org/opensearch/index/store/CompositeDirectory.java
              
                Outdated
          
            Show resolved
            Hide resolved
        
      | ❌ Gradle check result for 17b43da: FAILURE Please examine the workflow log, locate, and copy-paste the failure(s) below, then iterate to green. Is the failure a flaky test unrelated to your change? | 
Signed-off-by: Sandeep Kumawat <skumwt@amazon.com>
17b43da    to
    b216afc      
    Compare
  
    | ❕ Gradle check result for b216afc: UNSTABLE Please review all flaky tests that succeeded after retry and create an issue if one does not already exist to track the flaky failure. | 
| Codecov ReportAttention: Patch coverage is  
 Additional details and impacted files@@             Coverage Diff              @@
##               main   #17390      +/-   ##
============================================
- Coverage     72.59%   72.41%   -0.18%     
+ Complexity    65798    65727      -71     
============================================
  Files          5311     5311              
  Lines        304888   304924      +36     
  Branches      44212    44225      +13     
============================================
- Hits         221323   220819     -504     
- Misses        65501    66021     +520     
- Partials      18064    18084      +20     ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
 | 
Signed-off-by: Sandeep Kumawat <skumwt@amazon.com> (cherry picked from commit cb869c0) Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Signed-off-by: Sandeep Kumawat <skumwt@amazon.com> Signed-off-by: Vinay Krishna Pudyodu <vinkrish.neo@gmail.com>
Signed-off-by: Sandeep Kumawat <skumwt@amazon.com>
Description
This PR aims to implement the Replica Replication and Recovery flow for indices with partial store locality (also known as writable warm indices), which were introduced with the composite directory in PR #12782.
For writable indices, where primary shards now consist of both localDirectory and remoteDirectory, we've implemented file uploads to remote storage and maintain an LRU fileCache on the node instead of storing all files locally.
We've made several changes to the replication and recovery processes:
Related Issues
Resolves #13647
Check List
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.