Revert "Create Version File in Datanode. Contributed by Bharat Viswanadham."

This reverts commit f26d3466d79125123cba00ab81481655d7bfe3c1.
This commit is contained in:
Hanisha Koneru 2018-06-11 12:15:39 -07:00
parent 143dd560bf
commit 0e437f9b17
14 changed files with 14 additions and 688 deletions

View File

@ -29,8 +29,6 @@ public final class OzoneConsts {
public static final String STORAGE_DIR = "scm"; public static final String STORAGE_DIR = "scm";
public static final String SCM_ID = "scmUuid"; public static final String SCM_ID = "scmUuid";
public static final String LAYOUTVERSION = "layOutVersion";
public static final String CTIME = "ctime";
public static final String OZONE_SIMPLE_ROOT_USER = "root"; public static final String OZONE_SIMPLE_ROOT_USER = "root";
public static final String OZONE_SIMPLE_HDFS_USER = "hdfs"; public static final String OZONE_SIMPLE_HDFS_USER = "hdfs";

View File

@ -45,10 +45,8 @@ import java.util.Properties;
public abstract class Storage { public abstract class Storage {
private static final Logger LOG = LoggerFactory.getLogger(Storage.class); private static final Logger LOG = LoggerFactory.getLogger(Storage.class);
public static final String STORAGE_DIR_CURRENT = "current"; protected static final String STORAGE_DIR_CURRENT = "current";
public static final String STORAGE_FILE_VERSION = "VERSION"; protected static final String STORAGE_FILE_VERSION = "VERSION";
public static final String STORAGE_DIR_HDDS = "hdds";
private final NodeType nodeType; private final NodeType nodeType;
private final File root; private final File root;

View File

@ -1,80 +0,0 @@
/**
* 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.ozone.container.common;
/**
* Datanode layout version which describes information about the layout version
* on the datanode.
*/
public final class DataNodeLayoutVersion {
// We will just be normal and use positive counting numbers for versions.
private final static DataNodeLayoutVersion[] VERSION_INFOS =
{new DataNodeLayoutVersion(1, "HDDS Datanode LayOut Version 1")};
private final String description;
private final int version;
/**
* Never created outside this class.
*
* @param description -- description
* @param version -- version number
*/
private DataNodeLayoutVersion(int version, String description) {
this.description = description;
this.version = version;
}
/**
* Returns all versions.
*
* @return Version info array.
*/
public static DataNodeLayoutVersion[] getAllVersions() {
return VERSION_INFOS.clone();
}
/**
* Returns the latest version.
*
* @return versionInfo
*/
public static DataNodeLayoutVersion getLatestVersion() {
return VERSION_INFOS[VERSION_INFOS.length - 1];
}
/**
* Return description.
*
* @return String
*/
public String getDescription() {
return description;
}
/**
* Return the version.
*
* @return int.
*/
public int getVersion() {
return version;
}
}

View File

@ -1,172 +0,0 @@
/**
* 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
* <p>
* http://www.apache.org/licenses/LICENSE-2.0
* <p>
* 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.ozone.container.common.helpers;
import com.google.common.annotations.VisibleForTesting;
import com.google.common.base.Preconditions;
import org.apache.commons.lang.StringUtils;
import org.apache.hadoop.hdfs.server.datanode.StorageLocation;
import org.apache.hadoop.ozone.OzoneConsts;
import org.apache.hadoop.ozone.common.InconsistentStorageStateException;
import org.apache.hadoop.ozone.common.Storage;
import org.apache.hadoop.ozone.container.common.DataNodeLayoutVersion;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.util.Properties;
/**
* This is a utility class which helps to create the version file on datanode
* and also validate the content of the version file.
*/
public class DatanodeVersionFile {
private final String scmUuid;
private final long cTime;
private final int layOutVersion;
public DatanodeVersionFile(String scmUuid, long cTime, int layOutVersion) {
this.scmUuid = scmUuid;
this.cTime = cTime;
this.layOutVersion = layOutVersion;
}
private Properties createProperties() {
Properties properties = new Properties();
properties.setProperty(OzoneConsts.SCM_ID, scmUuid);
properties.setProperty(OzoneConsts.CTIME, String.valueOf(cTime));
properties.setProperty(OzoneConsts.LAYOUTVERSION, String.valueOf(
layOutVersion));
return properties;
}
/**
* Creates a version File in specified path.
* @param path
* @throws IOException
*/
public void createVersionFile(File path) throws
IOException {
try (RandomAccessFile file = new RandomAccessFile(path, "rws");
FileOutputStream out = new FileOutputStream(file.getFD())) {
file.getChannel().truncate(0);
Properties properties = createProperties();
/*
* If server is interrupted before this line,
* the version file will remain unchanged.
*/
properties.store(out, null);
/*
* Now the new fields are flushed to the head of the file, but file
* length can still be larger then required and therefore the file can
* contain whole or corrupted fields from its old contents in the end.
* If server is interrupted here and restarted later these extra fields
* either should not effect server behavior or should be handled
* by the server correctly.
*/
file.getChannel().truncate(file.getChannel().size());
}
}
/**
* Creates a property object from the specified file content.
* @param versionFile
* @return Properties
* @throws IOException
*/
public static Properties readFrom(File versionFile) throws IOException {
try (RandomAccessFile file = new RandomAccessFile(versionFile, "rws");
FileInputStream in = new FileInputStream(file.getFD())) {
Properties props = new Properties();
props.load(in);
return props;
}
}
/**
* Verifies scmUuid is valid or not.
* @param scmIdVersionFile
* @param scmId
* @throws InconsistentStorageStateException
*/
@VisibleForTesting
public static void verifyScmUuid(String scmIdVersionFile, String scmId) throws
InconsistentStorageStateException {
Preconditions.checkState(StringUtils.isNotBlank(scmIdVersionFile),
"Invalid scmUuid from Version File.");
Preconditions.checkState(StringUtils.isNotBlank(scmId),
"Invalid scmUuid from SCM version request response");
if(!scmIdVersionFile.equals(scmId)) {
throw new InconsistentStorageStateException("MisMatch of ScmUuid " +
"scmUuid from version File is: " + scmIdVersionFile + "SCM " +
"version response scmUuid is" + scmId);
}
}
/**
* Verifies creationTime is valid or not.
* @param creationTime
*/
@VisibleForTesting
public static void verifyCreationTime(String creationTime) {
Preconditions.checkState(!StringUtils.isBlank(creationTime),
"Invalid creation Time.");
}
/**
* Verifies layOutVersion is valid or not.
* @param lv
* @throws InconsistentStorageStateException
*/
@VisibleForTesting
public static void verifyLayOutVersion(String lv) throws
InconsistentStorageStateException {
Preconditions.checkState(!StringUtils.isBlank(lv),
"Invalid layOutVersion.");
int version = Integer.parseInt(lv);
if(DataNodeLayoutVersion.getLatestVersion().getVersion() != version) {
throw new InconsistentStorageStateException("Incorrect layOutVersion");
}
}
/**
* Returns the versionFile path for the StorageLocation.
* @param location
* @param scmUuid
* @return versionFile - File
*/
@VisibleForTesting
public static File getVersionFile(StorageLocation location, String scmUuid) {
if (location != null) {
String path = location.getUri().getPath();
File parentPath = new File(path + File.separator + Storage
.STORAGE_DIR_HDDS + File.separator + scmUuid + File.separator +
Storage.STORAGE_DIR_CURRENT + File.separator);
File versionFile = new File(parentPath, Storage.STORAGE_FILE_VERSION);
return versionFile;
} else {
return null;
}
}
}

View File

@ -95,8 +95,7 @@ public class RunningDatanodeState implements DatanodeState {
getEndPointTask(EndpointStateMachine endpoint) { getEndPointTask(EndpointStateMachine endpoint) {
switch (endpoint.getState()) { switch (endpoint.getState()) {
case GETVERSION: case GETVERSION:
return new VersionEndpointTask(endpoint, conf, context.getParent(). return new VersionEndpointTask(endpoint, conf);
getContainer());
case REGISTER: case REGISTER:
return RegisterEndpointTask.newBuilder() return RegisterEndpointTask.newBuilder()
.setConfig(conf) .setConfig(conf)

View File

@ -16,30 +16,14 @@
*/ */
package org.apache.hadoop.ozone.container.common.states.endpoint; package org.apache.hadoop.ozone.container.common.states.endpoint;
import com.google.common.base.Preconditions;
import org.apache.commons.lang.StringUtils;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hdds.protocol.proto import org.apache.hadoop.hdds.protocol.proto
.StorageContainerDatanodeProtocolProtos.SCMVersionResponseProto; .StorageContainerDatanodeProtocolProtos.SCMVersionResponseProto;
import org.apache.hadoop.hdfs.server.datanode.StorageLocation;
import org.apache.hadoop.ozone.OzoneConsts;
import org.apache.hadoop.ozone.common.InconsistentStorageStateException;
import org.apache.hadoop.ozone.common.Storage;
import org.apache.hadoop.ozone.container.common.DataNodeLayoutVersion;
import org.apache.hadoop.ozone.container.common.helpers.DatanodeVersionFile;
import org.apache.hadoop.ozone.container.common.statemachine import org.apache.hadoop.ozone.container.common.statemachine
.EndpointStateMachine; .EndpointStateMachine;
import org.apache.hadoop.ozone.container.ozoneimpl.OzoneContainer;
import org.apache.hadoop.ozone.protocol.VersionResponse; import org.apache.hadoop.ozone.protocol.VersionResponse;
import org.apache.hadoop.util.Time;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.List;
import java.util.Properties;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
/** /**
@ -49,15 +33,11 @@ public class VersionEndpointTask implements
Callable<EndpointStateMachine.EndPointStates> { Callable<EndpointStateMachine.EndPointStates> {
private final EndpointStateMachine rpcEndPoint; private final EndpointStateMachine rpcEndPoint;
private final Configuration configuration; private final Configuration configuration;
private final OzoneContainer datanodeContainerManager;
static final Logger LOG =
LoggerFactory.getLogger(VersionEndpointTask.class);
public VersionEndpointTask(EndpointStateMachine rpcEndPoint, public VersionEndpointTask(EndpointStateMachine rpcEndPoint,
Configuration conf, OzoneContainer container) { Configuration conf) {
this.rpcEndPoint = rpcEndPoint; this.rpcEndPoint = rpcEndPoint;
this.configuration = conf; this.configuration = conf;
this.datanodeContainerManager = container;
} }
/** /**
@ -69,56 +49,15 @@ public class VersionEndpointTask implements
@Override @Override
public EndpointStateMachine.EndPointStates call() throws Exception { public EndpointStateMachine.EndPointStates call() throws Exception {
rpcEndPoint.lock(); rpcEndPoint.lock();
try { try{
SCMVersionResponseProto versionResponse = SCMVersionResponseProto versionResponse =
rpcEndPoint.getEndPoint().getVersion(null); rpcEndPoint.getEndPoint().getVersion(null);
VersionResponse response = VersionResponse.getFromProtobuf( rpcEndPoint.setVersion(VersionResponse.getFromProtobuf(versionResponse));
versionResponse);
String scmUuid = response.getValue(OzoneConsts.SCM_ID);
Preconditions.checkState(!StringUtils.isBlank(scmUuid),
"Invalid SCM UuiD in the response.");
rpcEndPoint.setVersion(response); EndpointStateMachine.EndPointStates nextState =
LOG.debug("scmUuid is {}", scmUuid); rpcEndPoint.getState().getNextState();
List<StorageLocation> locations = datanodeContainerManager.getLocations();
for (StorageLocation location : locations) {
String path = location.getUri().getPath();
File parentPath = new File(path + File.separator + Storage
.STORAGE_DIR_HDDS + File.separator + scmUuid + File.separator +
Storage.STORAGE_DIR_CURRENT);
File versionFile = DatanodeVersionFile.getVersionFile(location,
scmUuid);
if (!parentPath.exists() && !parentPath.mkdirs()) {
LOG.error("Directory doesn't exist and cannot be created. Path: {}",
parentPath.toString());
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.SHUTDOWN);
throw new IllegalArgumentException("Directory doesn't exist and " +
"cannot be created. " + parentPath.toString());
} else {
if (versionFile.exists()) {
Properties properties = DatanodeVersionFile.readFrom(versionFile);
DatanodeVersionFile.verifyScmUuid(properties.getProperty(
OzoneConsts.SCM_ID), scmUuid);
DatanodeVersionFile.verifyCreationTime(properties.getProperty(
OzoneConsts.CTIME));
DatanodeVersionFile.verifyLayOutVersion(properties.getProperty(
OzoneConsts.LAYOUTVERSION));
} else {
DatanodeVersionFile dnVersionFile = new DatanodeVersionFile(scmUuid,
Time.now(), DataNodeLayoutVersion.getLatestVersion()
.getVersion());
dnVersionFile.createVersionFile(versionFile);
}
}
}
EndpointStateMachine.EndPointStates nextState = rpcEndPoint.getState().
getNextState();
rpcEndPoint.setState(nextState); rpcEndPoint.setState(nextState);
rpcEndPoint.zeroMissedCount(); rpcEndPoint.zeroMissedCount();
} catch (InconsistentStorageStateException ex) {
throw ex;
} catch (IOException ex) { } catch (IOException ex) {
rpcEndPoint.logIfNeeded(ex); rpcEndPoint.logIfNeeded(ex);
} finally { } finally {

View File

@ -51,7 +51,6 @@ import org.slf4j.LoggerFactory;
import java.io.IOException; import java.io.IOException;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.util.Collections;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -83,7 +82,6 @@ public class OzoneContainer {
private final ChunkManager chunkManager; private final ChunkManager chunkManager;
private final KeyManager keyManager; private final KeyManager keyManager;
private final BlockDeletingService blockDeletingService; private final BlockDeletingService blockDeletingService;
private final List<StorageLocation> locations;
/** /**
* Creates a network endpoint and enables Ozone container. * Creates a network endpoint and enables Ozone container.
@ -95,7 +93,7 @@ public class OzoneContainer {
DatanodeDetails datanodeDetails, Configuration ozoneConfig) DatanodeDetails datanodeDetails, Configuration ozoneConfig)
throws IOException { throws IOException {
this.ozoneConfig = ozoneConfig; this.ozoneConfig = ozoneConfig;
locations = new LinkedList<>(); List<StorageLocation> locations = new LinkedList<>();
String[] paths = ozoneConfig.getStrings( String[] paths = ozoneConfig.getStrings(
OzoneConfigKeys.OZONE_METADATA_DIRS); OzoneConfigKeys.OZONE_METADATA_DIRS);
if (paths != null && paths.length > 0) { if (paths != null && paths.length > 0) {
@ -139,10 +137,6 @@ public class OzoneContainer {
}; };
} }
public List<StorageLocation> getLocations() {
return Collections.unmodifiableList(this.locations);
}
/** /**
* Starts serving requests to ozone container. * Starts serving requests to ozone container.
* *

View File

@ -88,10 +88,6 @@ public class VersionResponse {
values.put(key, value); values.put(key, value);
} }
public String getValue(String key) {
return this.values.get(key);
}
/** /**
* Return a protobuf message. * Return a protobuf message.
* @return SCMVersionResponseProto. * @return SCMVersionResponseProto.

View File

@ -57,28 +57,6 @@ public class ScmTestMock implements StorageContainerDatanodeProtocol {
private Map<DatanodeDetails, Map<String, ContainerInfo>> nodeContainers = private Map<DatanodeDetails, Map<String, ContainerInfo>> nodeContainers =
new HashMap(); new HashMap();
private Map<DatanodeDetails, NodeReportProto> nodeReports = new HashMap<>(); private Map<DatanodeDetails, NodeReportProto> nodeReports = new HashMap<>();
private UUID scmUuid;
public ScmTestMock() {
scmUuid = UUID.randomUUID();
}
/**
* Return scmUuid.
* @return UUID
*/
public UUID getScmUuid() {
return scmUuid;
}
/**
* set scmUuid.
* @param id
*/
public void setSCMUuid(UUID id) {
this.scmUuid = id;
}
/** /**
* Returns the number of heartbeats made to this class. * Returns the number of heartbeats made to this class.
* *
@ -169,11 +147,9 @@ public class ScmTestMock implements StorageContainerDatanodeProtocol {
rpcCount.incrementAndGet(); rpcCount.incrementAndGet();
sleepIfNeeded(); sleepIfNeeded();
VersionInfo versionInfo = VersionInfo.getLatestVersion(); VersionInfo versionInfo = VersionInfo.getLatestVersion();
return VersionResponse.newBuilder() return VersionResponse.newBuilder()
.setVersion(versionInfo.getVersion()) .setVersion(versionInfo.getVersion())
.addValue(VersionInfo.DESCRIPTION_KEY, versionInfo.getDescription()) .addValue(VersionInfo.DESCRIPTION_KEY, versionInfo.getDescription())
.addValue("scmUuid", scmUuid.toString())
.build().getProtobufMessage(); .build().getProtobufMessage();
} }

View File

@ -1,38 +0,0 @@
/**
* 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
* <p>
* http://www.apache.org/licenses/LICENSE-2.0
* <p>
* 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.ozone.container.common;
import org.junit.Assert;
import org.junit.Test;
/**
* This class tests DatanodeLayOutVersion.
*/
public class TestDatanodeLayOutVersion {
@Test
public void testDatanodeLayOutVersion() {
// Check Latest Version and description
Assert.assertEquals(1, DataNodeLayoutVersion.getLatestVersion()
.getVersion());
Assert.assertEquals("HDDS Datanode LayOut Version 1", DataNodeLayoutVersion
.getLatestVersion().getDescription());
Assert.assertEquals(DataNodeLayoutVersion.getAllVersions().length,
DataNodeLayoutVersion.getAllVersions().length);
}
}

View File

@ -19,7 +19,6 @@ package org.apache.hadoop.ozone.container.common;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
import com.google.common.util.concurrent.ThreadFactoryBuilder; import com.google.common.util.concurrent.ThreadFactoryBuilder;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.hdds.scm.ScmConfigKeys; import org.apache.hadoop.hdds.scm.ScmConfigKeys;
import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.hdds.protocol.DatanodeDetails;
import org.apache.hadoop.ipc.RPC; import org.apache.hadoop.ipc.RPC;
@ -146,7 +145,7 @@ public class TestDatanodeStateMachine {
} catch (Exception e) { } catch (Exception e) {
//ignore all execption from the shutdown //ignore all execption from the shutdown
} finally { } finally {
FileUtil.fullyDelete(testRoot); testRoot.delete();
} }
} }

View File

@ -1,120 +0,0 @@
/**
* 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
* <p>
* http://www.apache.org/licenses/LICENSE-2.0
* <p>
* 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.ozone.container.common.helpers;
import org.apache.hadoop.hdfs.server.datanode.StorageLocation;
import org.apache.hadoop.ozone.OzoneConsts;
import org.apache.hadoop.ozone.common.InconsistentStorageStateException;
import org.apache.hadoop.ozone.container.common.DataNodeLayoutVersion;
import org.apache.hadoop.test.GenericTestUtils;
import org.apache.hadoop.util.Time;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TemporaryFolder;
import java.io.File;
import java.io.IOException;
import java.util.Properties;
import java.util.UUID;
import static org.junit.Assert.*;
/**
* This class tests DatanodeVersionFile.
*/
public class TestDatanodeVersionFile {
@Rule
public TemporaryFolder folder= new TemporaryFolder();
@Test
public void testCreateAndReadVersionFile() throws IOException{
File versionFile = folder.newFile("Version");
String uuid = UUID.randomUUID().toString();
long now = Time.now();
int lv = DataNodeLayoutVersion.getLatestVersion().getVersion();
DatanodeVersionFile dnVersionFile = new DatanodeVersionFile(uuid, now, lv);
dnVersionFile.createVersionFile(versionFile);
//Check VersionFile exists
assertTrue(versionFile.exists());
Properties properties = dnVersionFile.readFrom(versionFile);
assertEquals(uuid, properties.getProperty(OzoneConsts.SCM_ID));
assertEquals(String.valueOf(now), properties.get(OzoneConsts.CTIME));
assertEquals(String.valueOf(lv), properties.get(OzoneConsts.LAYOUTVERSION));
DatanodeVersionFile.verifyCreationTime(String.valueOf(properties.get(
OzoneConsts.CTIME)));
DatanodeVersionFile.verifyLayOutVersion(String.valueOf(properties
.getProperty(OzoneConsts.LAYOUTVERSION)));
DatanodeVersionFile.verifyScmUuid(uuid, String.valueOf(properties
.getProperty(OzoneConsts.SCM_ID)));
}
@Test
public void testVerifyUuid() throws IOException{
String uuid = UUID.randomUUID().toString();
try {
DatanodeVersionFile.verifyScmUuid(uuid, uuid);
DatanodeVersionFile.verifyScmUuid(uuid, UUID.randomUUID().toString());
fail("Test failure in testVerifyUuid");
} catch (InconsistentStorageStateException ex) {
GenericTestUtils.assertExceptionContains("MisMatch of ScmUuid", ex);
}
}
@Test
public void testVerifyCTime() throws IOException{
try {
DatanodeVersionFile.verifyCreationTime(String.valueOf(Time.now()));
DatanodeVersionFile.verifyCreationTime(null);
fail("Test failure in testVerifyCTime");
} catch (IllegalStateException ex) {
GenericTestUtils.assertExceptionContains("Invalid creation Time.", ex);
}
}
@Test
public void testVerifyLayOut() throws IOException{
String lv = String.valueOf(DataNodeLayoutVersion.getLatestVersion()
.getVersion());
try {
DatanodeVersionFile.verifyLayOutVersion(lv);
DatanodeVersionFile.verifyLayOutVersion(null);
fail("Test failure in testVerifyLayOut");
} catch (IllegalStateException ex) {
GenericTestUtils.assertExceptionContains("Invalid layOutVersion.", ex);
}
}
@Test
public void testGetVersionFile() throws IOException {
StorageLocation location = StorageLocation.parse("/tmp/disk1");
String scmId = UUID.randomUUID().toString();
assertEquals(new File("/tmp/disk1/hdds/" + scmId + "/current/VERSION"),
DatanodeVersionFile.getVersionFile(location, scmId));
assertEquals(null, DatanodeVersionFile.getVersionFile(null, scmId));
}
}

View File

@ -40,7 +40,6 @@ import org.apache.hadoop.hdds.protocol.proto
.StorageContainerDatanodeProtocolProtos.SCMVersionRequestProto; .StorageContainerDatanodeProtocolProtos.SCMVersionRequestProto;
import org.apache.hadoop.ipc.Server; import org.apache.hadoop.ipc.Server;
import org.apache.hadoop.metrics2.util.MBeans; import org.apache.hadoop.metrics2.util.MBeans;
import org.apache.hadoop.ozone.OzoneConsts;
import org.apache.hadoop.ozone.protocol.StorageContainerNodeProtocol; import org.apache.hadoop.ozone.protocol.StorageContainerNodeProtocol;
import org.apache.hadoop.ozone.protocol.VersionResponse; import org.apache.hadoop.ozone.protocol.VersionResponse;
import org.apache.hadoop.ozone.protocol.commands.RegisteredCommand; import org.apache.hadoop.ozone.protocol.commands.RegisteredCommand;
@ -704,7 +703,6 @@ public class SCMNodeManager
public VersionResponse getVersion(SCMVersionRequestProto versionRequest) { public VersionResponse getVersion(SCMVersionRequestProto versionRequest) {
return VersionResponse.newBuilder() return VersionResponse.newBuilder()
.setVersion(this.version.getVersion()) .setVersion(this.version.getVersion())
.addValue(OzoneConsts.SCM_ID, scmManager.getScmStorage().getScmId())
.build(); .build();
} }

View File

@ -19,7 +19,6 @@ package org.apache.hadoop.ozone.container.common;
import org.apache.commons.codec.digest.DigestUtils; import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.lang3.RandomUtils; import org.apache.commons.lang3.RandomUtils;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystemTestHelper;
import org.apache.hadoop.fs.FileUtil; import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.hdds.protocol.proto.StorageContainerDatanodeProtocolProtos; import org.apache.hadoop.hdds.protocol.proto.StorageContainerDatanodeProtocolProtos;
import org.apache.hadoop.hdds.scm.TestUtils; import org.apache.hadoop.hdds.scm.TestUtils;
@ -34,7 +33,6 @@ import org.apache.hadoop.hdds.protocol.proto
.StorageContainerDatanodeProtocolProtos.SCMHeartbeatResponseProto; .StorageContainerDatanodeProtocolProtos.SCMHeartbeatResponseProto;
import org.apache.hadoop.hdds.protocol.proto import org.apache.hadoop.hdds.protocol.proto
.StorageContainerDatanodeProtocolProtos.SCMRegisteredResponseProto; .StorageContainerDatanodeProtocolProtos.SCMRegisteredResponseProto;
import org.apache.hadoop.hdfs.server.datanode.StorageLocation;
import org.apache.hadoop.hdds.protocol.proto import org.apache.hadoop.hdds.protocol.proto
.StorageContainerDatanodeProtocolProtos.StorageReportProto; .StorageContainerDatanodeProtocolProtos.StorageReportProto;
import org.apache.hadoop.hdds.protocol.proto import org.apache.hadoop.hdds.protocol.proto
@ -43,7 +41,6 @@ import org.apache.hadoop.ipc.RPC;
import org.apache.hadoop.ozone.OzoneConfigKeys; import org.apache.hadoop.ozone.OzoneConfigKeys;
import org.apache.hadoop.ozone.OzoneConsts; import org.apache.hadoop.ozone.OzoneConsts;
import org.apache.hadoop.ozone.container.common.helpers.ContainerReport; import org.apache.hadoop.ozone.container.common.helpers.ContainerReport;
import org.apache.hadoop.ozone.container.common.helpers.DatanodeVersionFile;
import org.apache.hadoop.ozone.container.common.statemachine import org.apache.hadoop.ozone.container.common.statemachine
.DatanodeStateMachine; .DatanodeStateMachine;
import org.apache.hadoop.ozone.container.common.statemachine import org.apache.hadoop.ozone.container.common.statemachine
@ -56,22 +53,17 @@ import org.apache.hadoop.ozone.container.common.states.endpoint
import org.apache.hadoop.ozone.container.common.states.endpoint import org.apache.hadoop.ozone.container.common.states.endpoint
.VersionEndpointTask; .VersionEndpointTask;
import org.apache.hadoop.ozone.container.ozoneimpl.OzoneContainer; import org.apache.hadoop.ozone.container.ozoneimpl.OzoneContainer;
import org.apache.hadoop.test.GenericTestUtils;
import org.apache.hadoop.test.PathUtils; import org.apache.hadoop.test.PathUtils;
import org.apache.hadoop.util.Time; import org.apache.hadoop.util.Time;
import org.junit.AfterClass; import org.junit.AfterClass;
import org.junit.Assert; import org.junit.Assert;
import org.junit.BeforeClass; import org.junit.BeforeClass;
import org.junit.Test; import org.junit.Test;
import static org.junit.Assert.fail;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import java.io.File; import java.io.File;
import java.net.InetSocketAddress; import java.net.InetSocketAddress;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Properties;
import java.util.UUID; import java.util.UUID;
import static org.apache.hadoop.hdds.scm.TestUtils.getDatanodeDetails; import static org.apache.hadoop.hdds.scm.TestUtils.getDatanodeDetails;
@ -124,11 +116,6 @@ public class TestEndPoint {
responseProto.getKeys(0).getKey()); responseProto.getKeys(0).getKey());
Assert.assertEquals(VersionInfo.getLatestVersion().getDescription(), Assert.assertEquals(VersionInfo.getLatestVersion().getDescription(),
responseProto.getKeys(0).getValue()); responseProto.getKeys(0).getValue());
Assert.assertEquals("scmUuid", responseProto.getKeys(
1).getKey());
Assert.assertEquals(scmServerImpl.getScmUuid().toString(),
responseProto.getKeys(1).getValue());
} }
} }
@ -139,20 +126,11 @@ public class TestEndPoint {
*/ */
public void testGetVersionTask() throws Exception { public void testGetVersionTask() throws Exception {
Configuration conf = SCMTestUtils.getConf(); Configuration conf = SCMTestUtils.getConf();
String path = new FileSystemTestHelper().getTestRootDir();
conf.set(DFS_DATANODE_DATA_DIR_KEY, path);
try (EndpointStateMachine rpcEndPoint = createEndpoint(conf, try (EndpointStateMachine rpcEndPoint = createEndpoint(conf,
serverAddress, 1000)) { serverAddress, 1000)) {
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION); rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
OzoneContainer ozoneContainer = mock(OzoneContainer.class);
List<StorageLocation> pathList = new ArrayList<>();
for (String dir : conf.getStrings(DFS_DATANODE_DATA_DIR_KEY)) {
StorageLocation location = StorageLocation.parse(dir);
pathList.add(location);
}
when(ozoneContainer.getLocations()).thenReturn(pathList);
VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint, VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint,
conf, ozoneContainer); conf);
EndpointStateMachine.EndPointStates newState = versionTask.call(); EndpointStateMachine.EndPointStates newState = versionTask.call();
// if version call worked the endpoint should automatically move to the // if version call worked the endpoint should automatically move to the
@ -162,131 +140,9 @@ public class TestEndPoint {
// Now rpcEndpoint should remember the version it got from SCM // Now rpcEndpoint should remember the version it got from SCM
Assert.assertNotNull(rpcEndPoint.getVersion()); Assert.assertNotNull(rpcEndPoint.getVersion());
FileUtil.fullyDelete(new File(path));
} }
} }
@Test
public void testVersionCheckFail() throws Exception {
Configuration conf = SCMTestUtils.getConf();
String path = new FileSystemTestHelper().getTestRootDir();
conf.set(DFS_DATANODE_DATA_DIR_KEY, path);
try (EndpointStateMachine rpcEndPoint = createEndpoint(conf,
serverAddress, 1000)) {
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
OzoneContainer ozoneContainer = mock(OzoneContainer.class);
List<StorageLocation> pathList = new ArrayList<>();
for (String dir : conf.getStrings(DFS_DATANODE_DATA_DIR_KEY)) {
StorageLocation location = StorageLocation.parse(dir);
pathList.add(location);
}
when(ozoneContainer.getLocations()).thenReturn(pathList);
VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint,
conf, ozoneContainer);
EndpointStateMachine.EndPointStates newState = versionTask.call();
// if version call worked the endpoint should automatically move to the
// next state.
Assert.assertEquals(EndpointStateMachine.EndPointStates.REGISTER,
newState);
// Now rpcEndpoint should remember the version it got from SCM
Assert.assertNotNull(rpcEndPoint.getVersion());
// Now call again version task with an incorrect layout version.
// This will fail with Incorrect layOutVersion error.
DatanodeVersionFile datanodeVersionFile = new DatanodeVersionFile(
scmServerImpl.getScmUuid().toString(), Time.now(), 2);
datanodeVersionFile.createVersionFile(DatanodeVersionFile
.getVersionFile(pathList.get(0), scmServerImpl.getScmUuid()
.toString()));
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
versionTask.call();
fail("Test fail");
} catch(Throwable t) {
GenericTestUtils.assertExceptionContains("Incorrect layOutVersion", t);
FileUtil.fullyDelete(new File(path));
}
}
@Test
public void testVersionCheckSuccess() throws Exception {
Configuration conf = SCMTestUtils.getConf();
String path = new FileSystemTestHelper().getTestRootDir();
conf.set(DFS_DATANODE_DATA_DIR_KEY, path);
try (EndpointStateMachine rpcEndPoint = createEndpoint(conf,
serverAddress, 1000)) {
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
OzoneContainer ozoneContainer = mock(OzoneContainer.class);
List<StorageLocation> pathList = new ArrayList<>();
for (String dir : conf.getStrings(DFS_DATANODE_DATA_DIR_KEY)) {
StorageLocation location = StorageLocation.parse(dir);
pathList.add(location);
}
when(ozoneContainer.getLocations()).thenReturn(pathList);
VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint,
conf, ozoneContainer);
EndpointStateMachine.EndPointStates newState = versionTask.call();
// if version call worked the endpoint should automatically move to the
// next state.
Assert.assertEquals(EndpointStateMachine.EndPointStates.REGISTER,
newState);
// Now rpcEndpoint should remember the version it got from SCM
Assert.assertNotNull(rpcEndPoint.getVersion());
// Now call again Version Task, this time version check should succeed.
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
newState = versionTask.call();
Assert.assertEquals(EndpointStateMachine.EndPointStates.REGISTER,
newState);
FileUtil.fullyDelete(new File(path));
}
}
@Test
public void testVersionCheckFile() throws Exception {
Configuration conf = SCMTestUtils.getConf();
FileUtil.fullyDelete(new File("/tmp/hadoop"));
conf.set(DFS_DATANODE_DATA_DIR_KEY, "/tmp/hadoop");
try (EndpointStateMachine rpcEndPoint = createEndpoint(conf,
serverAddress, 1000)) {
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
OzoneContainer ozoneContainer = mock(OzoneContainer.class);
List<StorageLocation> pathList = new ArrayList<>();
String dir = conf.get(DFS_DATANODE_DATA_DIR_KEY);
StorageLocation location = StorageLocation.parse(dir);
pathList.add(location);
when(ozoneContainer.getLocations()).thenReturn(pathList);
VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint,
conf, ozoneContainer);
EndpointStateMachine.EndPointStates newState = versionTask.call();
// if version call worked the endpoint should automatically move to the
// next state.
Assert.assertEquals(EndpointStateMachine.EndPointStates.REGISTER,
newState);
// Now rpcEndpoint should remember the version it got from SCM
Assert.assertNotNull(rpcEndPoint.getVersion());
// Check Version File created or not and content is expected or not.
File versionFile = DatanodeVersionFile.getVersionFile(pathList.get(0),
scmServerImpl.getScmUuid().toString());
Assert.assertTrue(versionFile.exists());
Properties props = DatanodeVersionFile.readFrom(versionFile);
DatanodeVersionFile.verifyCreationTime(props.getProperty(OzoneConsts
.CTIME));
DatanodeVersionFile.verifyScmUuid(scmServerImpl.getScmUuid().toString(),
props.getProperty(OzoneConsts.SCM_ID));
DatanodeVersionFile.verifyLayOutVersion(props.getProperty(OzoneConsts
.LAYOUTVERSION));
}
}
@Test @Test
/** /**
* This test makes a call to end point where there is no SCM server. We * This test makes a call to end point where there is no SCM server. We
@ -296,20 +152,11 @@ public class TestEndPoint {
Configuration conf = SCMTestUtils.getConf(); Configuration conf = SCMTestUtils.getConf();
InetSocketAddress nonExistentServerAddress = SCMTestUtils InetSocketAddress nonExistentServerAddress = SCMTestUtils
.getReuseableAddress(); .getReuseableAddress();
FileUtil.fullyDelete(new File("/tmp/hadoop"));
conf.set(DFS_DATANODE_DATA_DIR_KEY, "/tmp/hadoop");
try (EndpointStateMachine rpcEndPoint = createEndpoint(conf, try (EndpointStateMachine rpcEndPoint = createEndpoint(conf,
nonExistentServerAddress, 1000)) { nonExistentServerAddress, 1000)) {
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION); rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
OzoneContainer ozoneContainer = mock(OzoneContainer.class);
List<StorageLocation> pathList = new ArrayList<>();
for (String dir : conf.getStrings(DFS_DATANODE_DATA_DIR_KEY)) {
StorageLocation location = StorageLocation.parse(dir);
pathList.add(location);
}
when(ozoneContainer.getLocations()).thenReturn(pathList);
VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint, VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint,
conf, ozoneContainer); conf);
EndpointStateMachine.EndPointStates newState = versionTask.call(); EndpointStateMachine.EndPointStates newState = versionTask.call();
// This version call did NOT work, so endpoint should remain in the same // This version call did NOT work, so endpoint should remain in the same
@ -329,20 +176,12 @@ public class TestEndPoint {
final long rpcTimeout = 1000; final long rpcTimeout = 1000;
final long tolerance = 100; final long tolerance = 100;
Configuration conf = SCMTestUtils.getConf(); Configuration conf = SCMTestUtils.getConf();
FileUtil.fullyDelete(new File("/tmp/hadoop"));
conf.set(DFS_DATANODE_DATA_DIR_KEY, "/tmp/hadoop");
try (EndpointStateMachine rpcEndPoint = createEndpoint(conf, try (EndpointStateMachine rpcEndPoint = createEndpoint(conf,
serverAddress, (int) rpcTimeout)) { serverAddress, (int) rpcTimeout)) {
rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION); rpcEndPoint.setState(EndpointStateMachine.EndPointStates.GETVERSION);
OzoneContainer ozoneContainer = mock(OzoneContainer.class);
List<StorageLocation> pathList = new ArrayList<>();
for (String dir : conf.getStrings(DFS_DATANODE_DATA_DIR_KEY)) {
StorageLocation location = StorageLocation.parse(dir);
pathList.add(location);
}
when(ozoneContainer.getLocations()).thenReturn(pathList);
VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint, VersionEndpointTask versionTask = new VersionEndpointTask(rpcEndPoint,
conf, ozoneContainer); conf);
scmServerImpl.setRpcResponseDelay(1500); scmServerImpl.setRpcResponseDelay(1500);
long start = Time.monotonicNow(); long start = Time.monotonicNow();