HDFS-9569. Log the name of the fsimage being loaded for better supportability. (Yongjun Zhang)
(cherry picked from commit 25051c3bd0
)
Conflicts:
hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/FSImageFormat.java
This commit is contained in:
parent
4b829c41ce
commit
4c09a75f3e
|
@ -16,6 +16,9 @@ Release 2.7.3 - UNRELEASED
|
||||||
|
|
||||||
HDFS-9574. Reduce client failures during datanode restart (kihwal)
|
HDFS-9574. Reduce client failures during datanode restart (kihwal)
|
||||||
|
|
||||||
|
HDFS-9569. Log the name of the fsimage being loaded for better
|
||||||
|
supportability. (Yongjun Zhang)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
BUG FIXES
|
BUG FIXES
|
||||||
|
|
|
@ -669,14 +669,19 @@ public class FSImage implements Closeable {
|
||||||
LOG.info("No edit log streams selected.");
|
LOG.info("No edit log streams selected.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Exception le = null;
|
||||||
FSImageFile imageFile = null;
|
FSImageFile imageFile = null;
|
||||||
for (int i = 0; i < imageFiles.size(); i++) {
|
for (int i = 0; i < imageFiles.size(); i++) {
|
||||||
try {
|
try {
|
||||||
imageFile = imageFiles.get(i);
|
imageFile = imageFiles.get(i);
|
||||||
loadFSImageFile(target, recovery, imageFile, startOpt);
|
loadFSImageFile(target, recovery, imageFile, startOpt);
|
||||||
break;
|
break;
|
||||||
} catch (IOException ioe) {
|
} catch (IllegalReservedPathException ie) {
|
||||||
LOG.error("Failed to load image from " + imageFile, ioe);
|
throw new IOException("Failed to load image from " + imageFile,
|
||||||
|
ie);
|
||||||
|
} catch (Exception e) {
|
||||||
|
le = e;
|
||||||
|
LOG.error("Failed to load image from " + imageFile, e);
|
||||||
target.clear();
|
target.clear();
|
||||||
imageFile = null;
|
imageFile = null;
|
||||||
}
|
}
|
||||||
|
@ -684,7 +689,8 @@ public class FSImage implements Closeable {
|
||||||
// Failed to load any images, error out
|
// Failed to load any images, error out
|
||||||
if (imageFile == null) {
|
if (imageFile == null) {
|
||||||
FSEditLog.closeAllStreams(editStreams);
|
FSEditLog.closeAllStreams(editStreams);
|
||||||
throw new IOException("Failed to load an FSImage file!");
|
throw new IOException("Failed to load FSImage file, see error(s) " +
|
||||||
|
"above for more info.");
|
||||||
}
|
}
|
||||||
prog.endPhase(Phase.LOADING_FSIMAGE);
|
prog.endPhase(Phase.LOADING_FSIMAGE);
|
||||||
|
|
||||||
|
@ -727,7 +733,7 @@ public class FSImage implements Closeable {
|
||||||
|
|
||||||
void loadFSImageFile(FSNamesystem target, MetaRecoveryContext recovery,
|
void loadFSImageFile(FSNamesystem target, MetaRecoveryContext recovery,
|
||||||
FSImageFile imageFile, StartupOption startupOption) throws IOException {
|
FSImageFile imageFile, StartupOption startupOption) throws IOException {
|
||||||
LOG.debug("Planning to load image :\n" + imageFile);
|
LOG.info("Planning to load image: " + imageFile);
|
||||||
StorageDirectory sdForProperties = imageFile.sd;
|
StorageDirectory sdForProperties = imageFile.sd;
|
||||||
storage.readProperties(sdForProperties, startupOption);
|
storage.readProperties(sdForProperties, startupOption);
|
||||||
|
|
||||||
|
|
|
@ -666,7 +666,8 @@ public class FSImageFormat {
|
||||||
* This method is only used for image loading so that synchronization,
|
* This method is only used for image loading so that synchronization,
|
||||||
* modification time update and space count update are not needed.
|
* modification time update and space count update are not needed.
|
||||||
*/
|
*/
|
||||||
private void addToParent(INodeDirectory parent, INode child) {
|
private void addToParent(INodeDirectory parent, INode child)
|
||||||
|
throws IllegalReservedPathException {
|
||||||
FSDirectory fsDir = namesystem.dir;
|
FSDirectory fsDir = namesystem.dir;
|
||||||
if (parent == fsDir.rootDir) {
|
if (parent == fsDir.rootDir) {
|
||||||
child.setLocalName(renameReservedRootComponentOnUpgrade(
|
child.setLocalName(renameReservedRootComponentOnUpgrade(
|
||||||
|
@ -1094,7 +1095,7 @@ public class FSImageFormat {
|
||||||
* @return New path with reserved path components renamed to user value
|
* @return New path with reserved path components renamed to user value
|
||||||
*/
|
*/
|
||||||
static String renameReservedPathsOnUpgrade(String path,
|
static String renameReservedPathsOnUpgrade(String path,
|
||||||
final int layoutVersion) {
|
final int layoutVersion) throws IllegalReservedPathException {
|
||||||
final String oldPath = path;
|
final String oldPath = path;
|
||||||
// If any known LVs aren't supported, we're doing an upgrade
|
// If any known LVs aren't supported, we're doing an upgrade
|
||||||
if (!NameNodeLayoutVersion.supports(Feature.ADD_INODE_ID, layoutVersion)) {
|
if (!NameNodeLayoutVersion.supports(Feature.ADD_INODE_ID, layoutVersion)) {
|
||||||
|
@ -1144,13 +1145,13 @@ public class FSImageFormat {
|
||||||
* byte array path component.
|
* byte array path component.
|
||||||
*/
|
*/
|
||||||
private static byte[] renameReservedComponentOnUpgrade(byte[] component,
|
private static byte[] renameReservedComponentOnUpgrade(byte[] component,
|
||||||
final int layoutVersion) {
|
final int layoutVersion) throws IllegalReservedPathException {
|
||||||
// If the LV doesn't support snapshots, we're doing an upgrade
|
// If the LV doesn't support snapshots, we're doing an upgrade
|
||||||
if (!NameNodeLayoutVersion.supports(Feature.SNAPSHOT, layoutVersion)) {
|
if (!NameNodeLayoutVersion.supports(Feature.SNAPSHOT, layoutVersion)) {
|
||||||
if (Arrays.equals(component, HdfsConstants.DOT_SNAPSHOT_DIR_BYTES)) {
|
if (Arrays.equals(component, HdfsConstants.DOT_SNAPSHOT_DIR_BYTES)) {
|
||||||
Preconditions.checkArgument(
|
if (!renameReservedMap.containsKey(HdfsConstants.DOT_SNAPSHOT_DIR)) {
|
||||||
renameReservedMap.containsKey(HdfsConstants.DOT_SNAPSHOT_DIR),
|
throw new IllegalReservedPathException(RESERVED_ERROR_MSG);
|
||||||
RESERVED_ERROR_MSG);
|
}
|
||||||
component =
|
component =
|
||||||
DFSUtil.string2Bytes(renameReservedMap
|
DFSUtil.string2Bytes(renameReservedMap
|
||||||
.get(HdfsConstants.DOT_SNAPSHOT_DIR));
|
.get(HdfsConstants.DOT_SNAPSHOT_DIR));
|
||||||
|
@ -1164,13 +1165,13 @@ public class FSImageFormat {
|
||||||
* byte array path component.
|
* byte array path component.
|
||||||
*/
|
*/
|
||||||
private static byte[] renameReservedRootComponentOnUpgrade(byte[] component,
|
private static byte[] renameReservedRootComponentOnUpgrade(byte[] component,
|
||||||
final int layoutVersion) {
|
final int layoutVersion) throws IllegalReservedPathException {
|
||||||
// If the LV doesn't support inode IDs, we're doing an upgrade
|
// If the LV doesn't support inode IDs, we're doing an upgrade
|
||||||
if (!NameNodeLayoutVersion.supports(Feature.ADD_INODE_ID, layoutVersion)) {
|
if (!NameNodeLayoutVersion.supports(Feature.ADD_INODE_ID, layoutVersion)) {
|
||||||
if (Arrays.equals(component, FSDirectory.DOT_RESERVED)) {
|
if (Arrays.equals(component, FSDirectory.DOT_RESERVED)) {
|
||||||
Preconditions.checkArgument(
|
if (!renameReservedMap.containsKey(HdfsConstants.DOT_SNAPSHOT_DIR)) {
|
||||||
renameReservedMap.containsKey(FSDirectory.DOT_RESERVED_STRING),
|
throw new IllegalReservedPathException(RESERVED_ERROR_MSG);
|
||||||
RESERVED_ERROR_MSG);
|
}
|
||||||
final String renameString = renameReservedMap
|
final String renameString = renameReservedMap
|
||||||
.get(FSDirectory.DOT_RESERVED_STRING);
|
.get(FSDirectory.DOT_RESERVED_STRING);
|
||||||
component =
|
component =
|
||||||
|
|
|
@ -0,0 +1,39 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.hadoop.hdfs.server.namenode;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when upgrading from software release that doesn't support reserved
|
||||||
|
* path to software release that supports reserved path, and when there is
|
||||||
|
* reserved path name in the Fsimage.
|
||||||
|
*/
|
||||||
|
@InterfaceAudience.Private
|
||||||
|
public class IllegalReservedPathException extends IOException {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
public IllegalReservedPathException(String message, Throwable cause) {
|
||||||
|
super(message, cause);
|
||||||
|
}
|
||||||
|
public IllegalReservedPathException(String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
|
@ -45,6 +45,7 @@ import org.apache.hadoop.hdfs.server.common.HdfsServerConstants.StartupOption;
|
||||||
import org.apache.hadoop.hdfs.server.namenode.FSImage;
|
import org.apache.hadoop.hdfs.server.namenode.FSImage;
|
||||||
import org.apache.hadoop.hdfs.server.namenode.FSImageFormat;
|
import org.apache.hadoop.hdfs.server.namenode.FSImageFormat;
|
||||||
import org.apache.hadoop.hdfs.server.namenode.FSImageTestUtil;
|
import org.apache.hadoop.hdfs.server.namenode.FSImageTestUtil;
|
||||||
|
import org.apache.hadoop.hdfs.server.namenode.IllegalReservedPathException;
|
||||||
import org.apache.hadoop.test.GenericTestUtils;
|
import org.apache.hadoop.test.GenericTestUtils;
|
||||||
import org.apache.hadoop.util.StringUtils;
|
import org.apache.hadoop.util.StringUtils;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
@ -326,7 +327,7 @@ public class TestDFSUpgradeFromImage {
|
||||||
fail("Upgrade did not fail with bad MD5");
|
fail("Upgrade did not fail with bad MD5");
|
||||||
} catch (IOException ioe) {
|
} catch (IOException ioe) {
|
||||||
String msg = StringUtils.stringifyException(ioe);
|
String msg = StringUtils.stringifyException(ioe);
|
||||||
if (!msg.contains("Failed to load an FSImage file")) {
|
if (!msg.contains("Failed to load FSImage file")) {
|
||||||
throw ioe;
|
throw ioe;
|
||||||
}
|
}
|
||||||
int md5failures = appender.countExceptionsWithMessage(
|
int md5failures = appender.countExceptionsWithMessage(
|
||||||
|
@ -485,10 +486,15 @@ public class TestDFSUpgradeFromImage {
|
||||||
.format(false)
|
.format(false)
|
||||||
.startupOption(StartupOption.UPGRADE)
|
.startupOption(StartupOption.UPGRADE)
|
||||||
.numDataNodes(0).build();
|
.numDataNodes(0).build();
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IOException ioe) {
|
||||||
GenericTestUtils.assertExceptionContains(
|
Throwable cause = ioe.getCause();
|
||||||
"reserved path component in this version",
|
if (cause != null && cause instanceof IllegalReservedPathException) {
|
||||||
e);
|
GenericTestUtils.assertExceptionContains(
|
||||||
|
"reserved path component in this version",
|
||||||
|
cause);
|
||||||
|
} else {
|
||||||
|
throw ioe;
|
||||||
|
}
|
||||||
} finally {
|
} finally {
|
||||||
if (cluster != null) {
|
if (cluster != null) {
|
||||||
cluster.shutdown();
|
cluster.shutdown();
|
||||||
|
|
Loading…
Reference in New Issue