HDFS-14396. Failed to load image from FSImageFile when downgrade from 3.x to 2.x. Contributed by Fei Hui.

This commit is contained in:
Akira Ajisaka 2019-08-23 15:27:32 +09:00
parent edd708527d
commit bd7baea5a5
No known key found for this signature in database
GPG Key ID: C1EDBB9CA400FD50
1 changed files with 11 additions and 4 deletions

View File

@ -813,6 +813,8 @@ public final class FSImageFormatProtobuf {
FSImageCompression compression, String filePath) throws IOException { FSImageCompression compression, String filePath) throws IOException {
StartupProgress prog = NameNode.getStartupProgress(); StartupProgress prog = NameNode.getStartupProgress();
MessageDigest digester = MD5Hash.getDigester(); MessageDigest digester = MD5Hash.getDigester();
int layoutVersion =
context.getSourceNamesystem().getEffectiveLayoutVersion();
underlyingOutputStream = new DigestOutputStream(new BufferedOutputStream( underlyingOutputStream = new DigestOutputStream(new BufferedOutputStream(
fout), digester); fout), digester);
@ -839,11 +841,16 @@ public final class FSImageFormatProtobuf {
// depends on this behavior. // depends on this behavior.
context.checkCancelled(); context.checkCancelled();
Step step;
// Erasure coding policies should be saved before inodes // Erasure coding policies should be saved before inodes
Step step = new Step(StepType.ERASURE_CODING_POLICIES, filePath); if (NameNodeLayoutVersion.supports(
prog.beginStep(Phase.SAVING_CHECKPOINT, step); NameNodeLayoutVersion.Feature.ERASURE_CODING, layoutVersion)) {
saveErasureCodingSection(b); step = new Step(StepType.ERASURE_CODING_POLICIES, filePath);
prog.endStep(Phase.SAVING_CHECKPOINT, step); prog.beginStep(Phase.SAVING_CHECKPOINT, step);
saveErasureCodingSection(b);
prog.endStep(Phase.SAVING_CHECKPOINT, step);
}
step = new Step(StepType.INODES, filePath); step = new Step(StepType.INODES, filePath);
prog.beginStep(Phase.SAVING_CHECKPOINT, step); prog.beginStep(Phase.SAVING_CHECKPOINT, step);