HADOOP-14048. REDO operation of WASB#AtomicRename should create placeholder blob for destination folder. Contributed by NITIN VERMA
(cherry picked from commit c571cda5c7
)
This commit is contained in:
parent
8dc8ecbb91
commit
2d059b5a40
|
@ -566,6 +566,16 @@ public class NativeAzureFileSystem extends FileSystem {
|
|||
// Remove the source folder. Don't check explicitly if it exists,
|
||||
// to avoid triggering redo recursively.
|
||||
try {
|
||||
// Rename the source folder 0-byte root file
|
||||
// as destination folder 0-byte root file.
|
||||
FileMetadata srcMetaData = this.getSourceMetadata();
|
||||
if (srcMetaData.getBlobMaterialization() == BlobMaterialization.Explicit) {
|
||||
// We already have a lease. So let's just rename the source blob
|
||||
// as destination blob under same lease.
|
||||
fs.getStoreInterface().rename(this.getSrcKey(), this.getDstKey(), false, lease);
|
||||
}
|
||||
|
||||
// Now we can safely delete the source folder.
|
||||
fs.getStoreInterface().delete(srcKey, lease);
|
||||
} catch (Exception e) {
|
||||
LOG.info("Unable to delete source folder during folder rename redo. "
|
||||
|
|
Loading…
Reference in New Issue