HADOOP-8398. Cleanup BlockLocation. Contributed by Eli Collins
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1338806 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
c4e4e56160
commit
b64cd82a34
@ -327,6 +327,8 @@ Release 2.0.0 - UNRELEASED
|
|||||||
|
|
||||||
HADOOP-8366 Use ProtoBuf for RpcResponseHeader (sanjay radia)
|
HADOOP-8366 Use ProtoBuf for RpcResponseHeader (sanjay radia)
|
||||||
|
|
||||||
|
HADOOP-8398. Cleanup BlockLocation. (eli)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
BUG FIXES
|
BUG FIXES
|
||||||
|
@ -17,29 +17,23 @@
|
|||||||
*/
|
*/
|
||||||
package org.apache.hadoop.fs;
|
package org.apache.hadoop.fs;
|
||||||
|
|
||||||
import java.io.DataInput;
|
|
||||||
import java.io.DataOutput;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.classification.InterfaceStability;
|
import org.apache.hadoop.classification.InterfaceStability;
|
||||||
import org.apache.hadoop.io.Text;
|
|
||||||
import org.apache.hadoop.io.Writable;
|
|
||||||
import org.apache.hadoop.io.WritableFactories;
|
|
||||||
import org.apache.hadoop.io.WritableFactory;
|
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* A BlockLocation lists hosts, offset and length
|
* Represents the network location of a block, information about the hosts
|
||||||
* of block.
|
* that contain block replicas, and other block metadata (E.g. the file
|
||||||
*
|
* offset associated with the block, length, whether it is corrupt, etc).
|
||||||
*/
|
*/
|
||||||
@InterfaceAudience.Public
|
@InterfaceAudience.Public
|
||||||
@InterfaceStability.Stable
|
@InterfaceStability.Stable
|
||||||
public class BlockLocation {
|
public class BlockLocation {
|
||||||
private String[] hosts; //hostnames of datanodes
|
private String[] hosts; // Datanode hostnames
|
||||||
private String[] names; //hostname:portNumber of datanodes
|
private String[] names; // Datanode IP:xferPort for accessing the block
|
||||||
private String[] topologyPaths; // full path name in network topology
|
private String[] topologyPaths; // Full path name in network topology
|
||||||
private long offset; //offset of the of the block in the file
|
private long offset; // Offset of the block in the file
|
||||||
private long length;
|
private long length;
|
||||||
private boolean corrupt;
|
private boolean corrupt;
|
||||||
|
|
||||||
@ -105,7 +99,7 @@ public class BlockLocation {
|
|||||||
* Get the list of hosts (hostname) hosting this block
|
* Get the list of hosts (hostname) hosting this block
|
||||||
*/
|
*/
|
||||||
public String[] getHosts() throws IOException {
|
public String[] getHosts() throws IOException {
|
||||||
if ((hosts == null) || (hosts.length == 0)) {
|
if (hosts == null || hosts.length == 0) {
|
||||||
return new String[0];
|
return new String[0];
|
||||||
} else {
|
} else {
|
||||||
return hosts;
|
return hosts;
|
||||||
@ -113,25 +107,25 @@ public class BlockLocation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the list of names (hostname:port) hosting this block
|
* Get the list of names (IP:xferPort) hosting this block
|
||||||
*/
|
*/
|
||||||
public String[] getNames() throws IOException {
|
public String[] getNames() throws IOException {
|
||||||
if ((names == null) || (names.length == 0)) {
|
if (names == null || names.length == 0) {
|
||||||
return new String[0];
|
return new String[0];
|
||||||
} else {
|
} else {
|
||||||
return this.names;
|
return names;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the list of network topology paths for each of the hosts.
|
* Get the list of network topology paths for each of the hosts.
|
||||||
* The last component of the path is the host.
|
* The last component of the path is the "name" (IP:xferPort).
|
||||||
*/
|
*/
|
||||||
public String[] getTopologyPaths() throws IOException {
|
public String[] getTopologyPaths() throws IOException {
|
||||||
if ((topologyPaths == null) || (topologyPaths.length == 0)) {
|
if (topologyPaths == null || topologyPaths.length == 0) {
|
||||||
return new String[0];
|
return new String[0];
|
||||||
} else {
|
} else {
|
||||||
return this.topologyPaths;
|
return topologyPaths;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ public interface Node {
|
|||||||
* @param location the location
|
* @param location the location
|
||||||
*/
|
*/
|
||||||
public void setNetworkLocation(String location);
|
public void setNetworkLocation(String location);
|
||||||
|
|
||||||
/** @return this node's name */
|
/** @return this node's name */
|
||||||
public String getName();
|
public String getName();
|
||||||
|
|
||||||
|
@ -110,7 +110,7 @@ public class NodeBase implements Node {
|
|||||||
* @return the path of a node
|
* @return the path of a node
|
||||||
*/
|
*/
|
||||||
public static String getPath(Node node) {
|
public static String getPath(Node node) {
|
||||||
return node.getNetworkLocation()+PATH_SEPARATOR_STR+node.getName();
|
return node.getNetworkLocation() + PATH_SEPARATOR_STR + node.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @return this node's path as its string representation */
|
/** @return this node's path as its string representation */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user