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:
parent
ca379e1c43
commit
aa12859890
|
@ -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;
|
||||||
try (Reader input =
|
|
||||||
new InputStreamReader(new FileInputStream(hostsFile), "UTF-8")) {
|
if (hostFile.length() > 0) {
|
||||||
allDNs = objectMapper.readValue(input, DatanodeAdminProperties[].class);
|
try (Reader input =
|
||||||
} catch (JsonMappingException jme) {
|
new InputStreamReader(new FileInputStream(hostFile),
|
||||||
// The old format doesn't have json top-level token to enclose the array.
|
"UTF-8")) {
|
||||||
// For backward compatibility, try parsing the old format.
|
allDNs = objectMapper.readValue(input, DatanodeAdminProperties[].class);
|
||||||
tryOldFormat = true;
|
} catch (JsonMappingException jme) {
|
||||||
LOG.warn("{} has invalid JSON format." +
|
// The old format doesn't have json top-level token to enclose
|
||||||
"Try the old format without top-level token defined.", hostsFile);
|
// the array.
|
||||||
|
// For backward compatibility, try parsing the old format.
|
||||||
|
tryOldFormat = true;
|
||||||
|
}
|
||||||
|
} 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()]);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue