Revert "HDFS-11156. Add new op GETFILEBLOCKLOCATIONS to WebHDFS REST API. Contributed by Weiwei Yang"
This reverts commit 3b80424d4f
.
This commit is contained in:
parent
79f830ed22
commit
1a7b2ab9bb
|
@ -19,7 +19,6 @@ package org.apache.hadoop.hdfs.web;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
import com.google.common.collect.Maps;
|
import com.google.common.collect.Maps;
|
||||||
import org.apache.hadoop.fs.BlockLocation;
|
|
||||||
import org.apache.hadoop.fs.ContentSummary;
|
import org.apache.hadoop.fs.ContentSummary;
|
||||||
import org.apache.hadoop.fs.ContentSummary.Builder;
|
import org.apache.hadoop.fs.ContentSummary.Builder;
|
||||||
import org.apache.hadoop.fs.FileChecksum;
|
import org.apache.hadoop.fs.FileChecksum;
|
||||||
|
@ -546,35 +545,4 @@ class JsonUtilClient {
|
||||||
lastLocatedBlock, isLastBlockComplete, null);
|
lastLocatedBlock, isLastBlockComplete, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Convert a Json map to BlockLocation. **/
|
|
||||||
static BlockLocation toBlockLocation(Map<String, Object> m)
|
|
||||||
throws IOException{
|
|
||||||
long length = ((Number) m.get("length")).longValue();
|
|
||||||
long offset = ((Number) m.get("offset")).longValue();
|
|
||||||
boolean corrupt = Boolean.
|
|
||||||
getBoolean(m.get("corrupt").toString());
|
|
||||||
String[] storageIds = toStringArray(getList(m, "storageIds"));
|
|
||||||
String[] cachedHosts = toStringArray(getList(m, "cachedHosts"));
|
|
||||||
String[] hosts = toStringArray(getList(m, "hosts"));
|
|
||||||
String[] names = toStringArray(getList(m, "names"));
|
|
||||||
String[] topologyPaths = toStringArray(getList(m, "topologyPaths"));
|
|
||||||
StorageType[] storageTypes = toStorageTypeArray(
|
|
||||||
getList(m, "storageTypes"));
|
|
||||||
return new BlockLocation(names, hosts, cachedHosts,
|
|
||||||
topologyPaths, storageIds, storageTypes,
|
|
||||||
offset, length, corrupt);
|
|
||||||
}
|
|
||||||
|
|
||||||
static String[] toStringArray(List<?> list) {
|
|
||||||
if (list == null) {
|
|
||||||
return null;
|
|
||||||
} else {
|
|
||||||
final String[] array = new String[list.size()];
|
|
||||||
int i = 0;
|
|
||||||
for (Object object : list) {
|
|
||||||
array[i++] = object.toString();
|
|
||||||
}
|
|
||||||
return array;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1573,20 +1573,13 @@ public class WebHdfsFileSystem extends FileSystem
|
||||||
statistics.incrementReadOps(1);
|
statistics.incrementReadOps(1);
|
||||||
storageStatistics.incrementOpCounter(OpType.GET_FILE_BLOCK_LOCATIONS);
|
storageStatistics.incrementOpCounter(OpType.GET_FILE_BLOCK_LOCATIONS);
|
||||||
|
|
||||||
final HttpOpParam.Op op = GetOpParam.Op.GETFILEBLOCKLOCATIONS;
|
final HttpOpParam.Op op = GetOpParam.Op.GET_BLOCK_LOCATIONS;
|
||||||
return new FsPathResponseRunner<BlockLocation[]>(op, p,
|
return new FsPathResponseRunner<BlockLocation[]>(op, p,
|
||||||
new OffsetParam(offset), new LengthParam(length)) {
|
new OffsetParam(offset), new LengthParam(length)) {
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
BlockLocation[] decodeResponse(Map<?,?> json) throws IOException {
|
BlockLocation[] decodeResponse(Map<?,?> json) throws IOException {
|
||||||
List<?> list = JsonUtilClient.getList(json, "BlockLocations");
|
return DFSUtilClient.locatedBlocks2Locations(
|
||||||
BlockLocation[] locations = new BlockLocation[list.size()];
|
JsonUtilClient.toLocatedBlocks(json));
|
||||||
for(int i=0; i<locations.length; i++) {
|
|
||||||
BlockLocation bl = JsonUtilClient.
|
|
||||||
toBlockLocation((Map<String, Object>) list.get(i));
|
|
||||||
locations[i] = bl;
|
|
||||||
}
|
|
||||||
return locations;
|
|
||||||
}
|
}
|
||||||
}.run();
|
}.run();
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,18 +33,8 @@ public class GetOpParam extends HttpOpParam<GetOpParam.Op> {
|
||||||
GETHOMEDIRECTORY(false, HttpURLConnection.HTTP_OK),
|
GETHOMEDIRECTORY(false, HttpURLConnection.HTTP_OK),
|
||||||
GETDELEGATIONTOKEN(false, HttpURLConnection.HTTP_OK, true),
|
GETDELEGATIONTOKEN(false, HttpURLConnection.HTTP_OK, true),
|
||||||
|
|
||||||
/**
|
/** GET_BLOCK_LOCATIONS is a private unstable op. */
|
||||||
* GET_BLOCK_LOCATIONS is a private/stable API op. It returns a
|
|
||||||
* {@link org.apache.hadoop.hdfs.protocol.LocatedBlocks}
|
|
||||||
* json object.
|
|
||||||
*/
|
|
||||||
GET_BLOCK_LOCATIONS(false, HttpURLConnection.HTTP_OK),
|
GET_BLOCK_LOCATIONS(false, HttpURLConnection.HTTP_OK),
|
||||||
/**
|
|
||||||
* GETFILEBLOCKLOCATIONS is the public op that complies with
|
|
||||||
* {@link org.apache.hadoop.fs.FileSystem#getFileBlockLocations}
|
|
||||||
* interface.
|
|
||||||
*/
|
|
||||||
GETFILEBLOCKLOCATIONS(false, HttpURLConnection.HTTP_OK),
|
|
||||||
GETACLSTATUS(false, HttpURLConnection.HTTP_OK),
|
GETACLSTATUS(false, HttpURLConnection.HTTP_OK),
|
||||||
GETXATTRS(false, HttpURLConnection.HTTP_OK),
|
GETXATTRS(false, HttpURLConnection.HTTP_OK),
|
||||||
LISTXATTRS(false, HttpURLConnection.HTTP_OK),
|
LISTXATTRS(false, HttpURLConnection.HTTP_OK),
|
||||||
|
|
|
@ -54,7 +54,6 @@ import javax.ws.rs.core.StreamingOutput;
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.fs.BlockLocation;
|
|
||||||
import org.apache.hadoop.fs.ContentSummary;
|
import org.apache.hadoop.fs.ContentSummary;
|
||||||
import org.apache.hadoop.fs.FileStatus;
|
import org.apache.hadoop.fs.FileStatus;
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
|
@ -885,22 +884,6 @@ public class NamenodeWebHdfsMethods {
|
||||||
excludeDatanodes.getValue(), offset, length, bufferSize);
|
excludeDatanodes.getValue(), offset, length, bufferSize);
|
||||||
return Response.temporaryRedirect(uri).type(MediaType.APPLICATION_OCTET_STREAM).build();
|
return Response.temporaryRedirect(uri).type(MediaType.APPLICATION_OCTET_STREAM).build();
|
||||||
}
|
}
|
||||||
case GETFILEBLOCKLOCATIONS:
|
|
||||||
{
|
|
||||||
final long offsetValue = offset.getValue();
|
|
||||||
final Long lengthValue = length.getValue();
|
|
||||||
|
|
||||||
try (final FileSystem fs = FileSystem.get(conf != null ?
|
|
||||||
conf : new Configuration())) {
|
|
||||||
BlockLocation[] locations = fs.getFileBlockLocations(
|
|
||||||
new org.apache.hadoop.fs.Path(fullpath),
|
|
||||||
offsetValue,
|
|
||||||
lengthValue != null? lengthValue: Long.MAX_VALUE);
|
|
||||||
final String js = JsonUtil.toJsonString("BlockLocations",
|
|
||||||
JsonUtil.toJsonArray(locations));
|
|
||||||
return Response.ok(js).type(MediaType.APPLICATION_JSON).build();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case GET_BLOCK_LOCATIONS:
|
case GET_BLOCK_LOCATIONS:
|
||||||
{
|
{
|
||||||
final long offsetValue = offset.getValue();
|
final long offsetValue = offset.getValue();
|
||||||
|
|
|
@ -393,34 +393,4 @@ public class JsonUtil {
|
||||||
return MAPPER.writeValueAsString(obj);
|
return MAPPER.writeValueAsString(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object[] toJsonArray(BlockLocation[] locations)
|
|
||||||
throws IOException {
|
|
||||||
if(locations == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
Object[] blockLocations = new Object[locations.length];
|
|
||||||
for(int i=0; i<locations.length; i++) {
|
|
||||||
blockLocations[i] = toJsonMap(locations[i]);
|
|
||||||
}
|
|
||||||
return blockLocations;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Map<String, Object> toJsonMap(
|
|
||||||
final BlockLocation blockLocation) throws IOException {
|
|
||||||
if (blockLocation == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
final Map<String, Object> m = new TreeMap<String, Object>();
|
|
||||||
m.put("length", blockLocation.getLength());
|
|
||||||
m.put("offset", blockLocation.getOffset());
|
|
||||||
m.put("corrupt", blockLocation.isCorrupt());
|
|
||||||
m.put("storageTypes", toJsonArray(blockLocation.getStorageTypes()));
|
|
||||||
m.put("storageIds", blockLocation.getStorageIds());
|
|
||||||
m.put("cachedHosts", blockLocation.getCachedHosts());
|
|
||||||
m.put("hosts", blockLocation.getHosts());
|
|
||||||
m.put("names", blockLocation.getNames());
|
|
||||||
m.put("topologyPaths", blockLocation.getTopologyPaths());
|
|
||||||
return m;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,6 @@ import java.net.URI;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.security.PrivilegedExceptionAction;
|
import java.security.PrivilegedExceptionAction;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
|
@ -79,8 +78,6 @@ import org.apache.hadoop.security.token.SecretManager.InvalidToken;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.test.GenericTestUtils;
|
import org.apache.hadoop.test.GenericTestUtils;
|
||||||
import org.apache.log4j.Level;
|
import org.apache.log4j.Level;
|
||||||
import org.codehaus.jackson.map.ObjectMapper;
|
|
||||||
import org.codehaus.jackson.map.type.MapType;
|
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.mockito.internal.util.reflection.Whitebox;
|
import org.mockito.internal.util.reflection.Whitebox;
|
||||||
|
@ -750,46 +747,6 @@ public class TestWebHDFS {
|
||||||
Assert.assertTrue(storageTypes != null && storageTypes.length > 0 &&
|
Assert.assertTrue(storageTypes != null && storageTypes.length > 0 &&
|
||||||
storageTypes[0] == StorageType.DISK);
|
storageTypes[0] == StorageType.DISK);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Query webhdfs REST API to get block locations
|
|
||||||
InetSocketAddress addr = cluster.getNameNode().getHttpAddress();
|
|
||||||
URL url = new URL("http", addr.getHostString(), addr.getPort(),
|
|
||||||
WebHdfsFileSystem.PATH_PREFIX + "/foo?op=GETFILEBLOCKLOCATIONS");
|
|
||||||
LOG.info("Sending GETFILEBLOCKLOCATIONS request " + url);
|
|
||||||
|
|
||||||
String response = getResponse(url, "GET");
|
|
||||||
LOG.info("The output of GETFILEBLOCKLOCATIONS request " + response);
|
|
||||||
// Expected output from rest API
|
|
||||||
// { "BlockLoactions" : [{Block_Loation_Json}, ...] }
|
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
|
||||||
MapType jsonType = mapper.getTypeFactory().constructMapType(
|
|
||||||
Map.class,
|
|
||||||
String.class,
|
|
||||||
BlockLocation[].class);
|
|
||||||
Map<String, BlockLocation[]> jsonMap = mapper.readValue(response,
|
|
||||||
jsonType);
|
|
||||||
BlockLocation[] array = jsonMap.get("BlockLocations");
|
|
||||||
|
|
||||||
for(int i=0; i<locations.length; i++) {
|
|
||||||
BlockLocation raw = locations[i];
|
|
||||||
BlockLocation rest = array[i];
|
|
||||||
Assert.assertEquals(raw.getLength(),
|
|
||||||
rest.getLength());
|
|
||||||
Assert.assertEquals(raw.getOffset(),
|
|
||||||
rest.getOffset());
|
|
||||||
Assert.assertArrayEquals(raw.getCachedHosts(),
|
|
||||||
rest.getCachedHosts());
|
|
||||||
Assert.assertArrayEquals(raw.getHosts(),
|
|
||||||
rest.getHosts());
|
|
||||||
Assert.assertArrayEquals(raw.getNames(),
|
|
||||||
rest.getNames());
|
|
||||||
Assert.assertArrayEquals(raw.getStorageIds(),
|
|
||||||
rest.getStorageIds());
|
|
||||||
Assert.assertArrayEquals(raw.getTopologyPaths(),
|
|
||||||
rest.getTopologyPaths());
|
|
||||||
Assert.assertArrayEquals(raw.getStorageTypes(),
|
|
||||||
rest.getStorageTypes());
|
|
||||||
}
|
|
||||||
} finally {
|
} finally {
|
||||||
if (cluster != null) {
|
if (cluster != null) {
|
||||||
cluster.shutdown();
|
cluster.shutdown();
|
||||||
|
@ -797,14 +754,6 @@ public class TestWebHDFS {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String getResponse(URL url, String httpRequestType)
|
|
||||||
throws IOException {
|
|
||||||
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
|
|
||||||
conn.setRequestMethod(httpRequestType);
|
|
||||||
conn.setInstanceFollowRedirects(false);
|
|
||||||
return IOUtils.toString(conn.getInputStream());
|
|
||||||
}
|
|
||||||
|
|
||||||
private WebHdfsFileSystem createWebHDFSAsTestUser(final Configuration conf,
|
private WebHdfsFileSystem createWebHDFSAsTestUser(final Configuration conf,
|
||||||
final URI uri, final String userName) throws Exception {
|
final URI uri, final String userName) throws Exception {
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue