HDFS-14121. Log message about the old hosts file format is misleading

(Contributed by Zsolt Venczel via Daniel Templeton)

Change-Id: I7ff548f6c82e0aeb08a7a50ca7c2c827db8726bb
This commit is contained in:
Zsolt Venczel 2018-12-14 13:02:45 +01:00 committed by Daniel Templeton
parent ca379e1c43
commit aa12859890
1 changed files with 29 additions and 12 deletions

View File

@ -23,6 +23,7 @@ import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectReader; import com.fasterxml.jackson.databind.ObjectReader;
import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.io.IOException; import java.io.IOException;
@ -61,26 +62,37 @@ public final class CombinedHostsFileReader {
private CombinedHostsFileReader() { private CombinedHostsFileReader() {
} }
private static final String REFER_TO_DOC_MSG = " For the correct JSON" +
" format please refer to the documentation (https://hadoop.apache" +
".org/docs/current/hadoop-project-dist/hadoop-hdfs/HdfsDataNodeAd" +
"minGuide.html#JSON-based_configuration)";
/** /**
* Deserialize a set of DatanodeAdminProperties from a json file. * Deserialize a set of DatanodeAdminProperties from a json file.
* @param hostsFile the input json file to read from * @param hostsFilePath the input json file to read from
* @return the set of DatanodeAdminProperties * @return the set of DatanodeAdminProperties
* @throws IOException * @throws IOException
*/ */
public static DatanodeAdminProperties[] public static DatanodeAdminProperties[]
readFile(final String hostsFile) throws IOException { readFile(final String hostsFilePath) throws IOException {
DatanodeAdminProperties[] allDNs = new DatanodeAdminProperties[0]; DatanodeAdminProperties[] allDNs = new DatanodeAdminProperties[0];
ObjectMapper objectMapper = new ObjectMapper(); ObjectMapper objectMapper = new ObjectMapper();
File hostFile = new File(hostsFilePath);
boolean tryOldFormat = false; boolean tryOldFormat = false;
if (hostFile.length() > 0) {
try (Reader input = try (Reader input =
new InputStreamReader(new FileInputStream(hostsFile), "UTF-8")) { new InputStreamReader(new FileInputStream(hostFile),
"UTF-8")) {
allDNs = objectMapper.readValue(input, DatanodeAdminProperties[].class); allDNs = objectMapper.readValue(input, DatanodeAdminProperties[].class);
} catch (JsonMappingException jme) { } catch (JsonMappingException jme) {
// The old format doesn't have json top-level token to enclose the array. // The old format doesn't have json top-level token to enclose
// the array.
// For backward compatibility, try parsing the old format. // For backward compatibility, try parsing the old format.
tryOldFormat = true; tryOldFormat = true;
LOG.warn("{} has invalid JSON format." + }
"Try the old format without top-level token defined.", hostsFile); } else {
LOG.warn(hostsFilePath + " is empty." + REFER_TO_DOC_MSG);
} }
if (tryOldFormat) { if (tryOldFormat) {
@ -89,13 +101,18 @@ public final class CombinedHostsFileReader {
JsonFactory jsonFactory = new JsonFactory(); JsonFactory jsonFactory = new JsonFactory();
List<DatanodeAdminProperties> all = new ArrayList<>(); List<DatanodeAdminProperties> all = new ArrayList<>();
try (Reader input = try (Reader input =
new InputStreamReader(new FileInputStream(hostsFile), "UTF-8")) { new InputStreamReader(new FileInputStream(hostsFilePath),
"UTF-8")) {
Iterator<DatanodeAdminProperties> iterator = Iterator<DatanodeAdminProperties> iterator =
objectReader.readValues(jsonFactory.createParser(input)); objectReader.readValues(jsonFactory.createParser(input));
while (iterator.hasNext()) { while (iterator.hasNext()) {
DatanodeAdminProperties properties = iterator.next(); DatanodeAdminProperties properties = iterator.next();
all.add(properties); all.add(properties);
} }
LOG.warn(hostsFilePath + " has legacy JSON format." + REFER_TO_DOC_MSG);
} catch (Throwable ex) {
LOG.warn(hostsFilePath + " has invalid JSON format." + REFER_TO_DOC_MSG,
ex);
} }
allDNs = all.toArray(new DatanodeAdminProperties[all.size()]); allDNs = all.toArray(new DatanodeAdminProperties[all.size()]);
} }