HDFS-8218. Move classes that used by ClientProtocol into hdfs-client. Contributed by Haohui Mai.

This commit is contained in:
Haohui Mai 2015-04-22 09:10:12 -07:00
parent a479669e96
commit 71c9f2f4e7
21 changed files with 52 additions and 42 deletions

View File

@ -1,9 +1,16 @@
<FindBugsFilter> <FindBugsFilter>
<Match> <Match>
<Or> <Or>
<Class name="org.apache.hadoop.fs.XAttr"/>
<Class name="org.apache.hadoop.fs.XAttr$Builder"/>
<Class name="org.apache.hadoop.hdfs.inotify.EventBatch"/>
<Class name="org.apache.hadoop.hdfs.protocol.HdfsFileStatus"/> <Class name="org.apache.hadoop.hdfs.protocol.HdfsFileStatus"/>
<Class name="org.apache.hadoop.hdfs.protocol.LocatedBlock"/> <Class name="org.apache.hadoop.hdfs.protocol.LocatedBlock"/>
<Class name="org.apache.hadoop.hdfs.protocol.BlockStoragePolicy"/>
<Class name="org.apache.hadoop.hdfs.protocol.CorruptFileBlocks"/>
<Class name="org.apache.hadoop.hdfs.protocol.DirectoryListing"/>
<Class name="org.apache.hadoop.hdfs.security.token.block.BlockTokenIdentifier"/> <Class name="org.apache.hadoop.hdfs.security.token.block.BlockTokenIdentifier"/>
<Class name="org.apache.hadoop.hdfs.security.token.block.DataEncryptionKey"/>
</Or> </Or>
<Bug pattern="EI_EXPOSE_REP,EI_EXPOSE_REP2" /> <Bug pattern="EI_EXPOSE_REP,EI_EXPOSE_REP2" />
</Match> </Match>

View File

@ -64,54 +64,54 @@ public class XAttr {
SYSTEM, SYSTEM,
RAW; RAW;
} }
private final NameSpace ns; private final NameSpace ns;
private final String name; private final String name;
private final byte[] value; private final byte[] value;
public static class Builder { public static class Builder {
private NameSpace ns = NameSpace.USER; private NameSpace ns = NameSpace.USER;
private String name; private String name;
private byte[] value; private byte[] value;
public Builder setNameSpace(NameSpace ns) { public Builder setNameSpace(NameSpace ns) {
this.ns = ns; this.ns = ns;
return this; return this;
} }
public Builder setName(String name) { public Builder setName(String name) {
this.name = name; this.name = name;
return this; return this;
} }
public Builder setValue(byte[] value) { public Builder setValue(byte[] value) {
this.value = value; this.value = value;
return this; return this;
} }
public XAttr build() { public XAttr build() {
return new XAttr(ns, name, value); return new XAttr(ns, name, value);
} }
} }
private XAttr(NameSpace ns, String name, byte[] value) { private XAttr(NameSpace ns, String name, byte[] value) {
this.ns = ns; this.ns = ns;
this.name = name; this.name = name;
this.value = value; this.value = value;
} }
public NameSpace getNameSpace() { public NameSpace getNameSpace() {
return ns; return ns;
} }
public String getName() { public String getName() {
return name; return name;
} }
public byte[] getValue() { public byte[] getValue() {
return value; return value;
} }
@Override @Override
public int hashCode() { public int hashCode() {
return new HashCodeBuilder(811, 67) return new HashCodeBuilder(811, 67)

View File

@ -154,7 +154,7 @@ public abstract class Event {
this.symlinkTarget = symlinkTarget; this.symlinkTarget = symlinkTarget;
return this; return this;
} }
public Builder overwrite(boolean overwrite) { public Builder overwrite(boolean overwrite) {
this.overwrite = overwrite; this.overwrite = overwrite;
return this; return this;
@ -224,7 +224,7 @@ public abstract class Event {
public String getSymlinkTarget() { public String getSymlinkTarget() {
return symlinkTarget; return symlinkTarget;
} }
public boolean getOverwrite() { public boolean getOverwrite() {
return overwrite; return overwrite;
} }

View File

@ -123,7 +123,7 @@ public class BlockStoragePolicy {
* Choose the storage types for storing the remaining replicas, given the * Choose the storage types for storing the remaining replicas, given the
* replication number, the storage types of the chosen replicas and * replication number, the storage types of the chosen replicas and
* the unavailable storage types. It uses fallback storage in case that * the unavailable storage types. It uses fallback storage in case that
* the desired storage type is unavailable. * the desired storage type is unavailable.
* *
* @param replication the replication number. * @param replication the replication number.
* @param chosen the storage types of the chosen replicas. * @param chosen the storage types of the chosen replicas.

View File

@ -61,7 +61,7 @@ public class CorruptFileBlocks {
Arrays.equals(files, other.files); Arrays.equals(files, other.files);
} }
@Override @Override
public int hashCode() { public int hashCode() {
int result = cookie.hashCode(); int result = cookie.hashCode();

View File

@ -28,13 +28,13 @@ import org.apache.hadoop.classification.InterfaceStability;
public class DirectoryListing { public class DirectoryListing {
private HdfsFileStatus[] partialListing; private HdfsFileStatus[] partialListing;
private int remainingEntries; private int remainingEntries;
/** /**
* constructor * constructor
* @param partialListing a partial listing of a directory * @param partialListing a partial listing of a directory
* @param remainingEntries number of entries that are left to be listed * @param remainingEntries number of entries that are left to be listed
*/ */
public DirectoryListing(HdfsFileStatus[] partialListing, public DirectoryListing(HdfsFileStatus[] partialListing,
int remainingEntries) { int remainingEntries) {
if (partialListing == null) { if (partialListing == null) {
throw new IllegalArgumentException("partial listing should not be null"); throw new IllegalArgumentException("partial listing should not be null");
@ -54,7 +54,7 @@ public class DirectoryListing {
public HdfsFileStatus[] getPartialListing() { public HdfsFileStatus[] getPartialListing() {
return partialListing; return partialListing;
} }
/** /**
* Get the number of remaining entries that are left to be listed * Get the number of remaining entries that are left to be listed
* @return the number of remaining entries that are left to be listed * @return the number of remaining entries that are left to be listed
@ -62,7 +62,7 @@ public class DirectoryListing {
public int getRemainingEntries() { public int getRemainingEntries() {
return remainingEntries; return remainingEntries;
} }
/** /**
* Check if there are more entries that are left to be listed * Check if there are more entries that are left to be listed
* @return true if there are more entries that are left to be listed; * @return true if there are more entries that are left to be listed;
@ -71,7 +71,7 @@ public class DirectoryListing {
public boolean hasMore() { public boolean hasMore() {
return remainingEntries != 0; return remainingEntries != 0;
} }
/** /**
* Get the last name in this list * Get the last name in this list
* @return the last name in the list if it is not empty; otherwise return null * @return the last name in the list if it is not empty; otherwise return null

View File

@ -25,15 +25,15 @@ import org.apache.hadoop.classification.InterfaceStability;
@InterfaceStability.Evolving @InterfaceStability.Evolving
public final class NSQuotaExceededException extends QuotaExceededException { public final class NSQuotaExceededException extends QuotaExceededException {
protected static final long serialVersionUID = 1L; protected static final long serialVersionUID = 1L;
private String prefix; private String prefix;
public NSQuotaExceededException() {} public NSQuotaExceededException() {}
public NSQuotaExceededException(String msg) { public NSQuotaExceededException(String msg) {
super(msg); super(msg);
} }
public NSQuotaExceededException(long quota, long count) { public NSQuotaExceededException(long quota, long count) {
super(quota, count); super(quota, count);
} }
@ -42,9 +42,9 @@ public final class NSQuotaExceededException extends QuotaExceededException {
public String getMessage() { public String getMessage() {
String msg = super.getMessage(); String msg = super.getMessage();
if (msg == null) { if (msg == null) {
msg = "The NameSpace quota (directories and files)" + msg = "The NameSpace quota (directories and files)" +
(pathName==null?"":(" of directory " + pathName)) + (pathName==null?"":(" of directory " + pathName)) +
" is exceeded: quota=" + quota + " file count=" + count; " is exceeded: quota=" + quota + " file count=" + count;
if (prefix != null) { if (prefix != null) {
msg = prefix + ": " + msg; msg = prefix + ": " + msg;

View File

@ -23,15 +23,15 @@ 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;
/** /**
* This exception is thrown when modification to HDFS results in violation * This exception is thrown when modification to HDFS results in violation
* of a directory quota. A directory quota might be namespace quota (limit * of a directory quota. A directory quota might be namespace quota (limit
* on number of files and directories) or a diskspace quota (limit on space * on number of files and directories) or a diskspace quota (limit on space
* taken by all the file under the directory tree). <br> <br> * taken by all the file under the directory tree). <br> <br>
* *
* The message for the exception specifies the directory where the quota * The message for the exception specifies the directory where the quota
* was violated and actual quotas. Specific message is generated in the * was violated and actual quotas. Specific message is generated in the
* corresponding Exception class: * corresponding Exception class:
* DSQuotaExceededException or * DSQuotaExceededException or
* NSQuotaExceededException * NSQuotaExceededException
*/ */
@ -42,22 +42,22 @@ public class QuotaExceededException extends IOException {
protected String pathName=null; protected String pathName=null;
protected long quota; // quota protected long quota; // quota
protected long count; // actual value protected long count; // actual value
protected QuotaExceededException() {} protected QuotaExceededException() {}
protected QuotaExceededException(String msg) { protected QuotaExceededException(String msg) {
super(msg); super(msg);
} }
protected QuotaExceededException(long quota, long count) { protected QuotaExceededException(long quota, long count) {
this.quota = quota; this.quota = quota;
this.count = count; this.count = count;
} }
public void setPathName(String path) { public void setPathName(String path) {
this.pathName = path; this.pathName = path;
} }
@Override @Override
public String getMessage() { public String getMessage() {
return super.getMessage(); return super.getMessage();

View File

@ -31,7 +31,7 @@ public class RollingUpgradeInfo extends RollingUpgradeStatus {
private final long startTime; private final long startTime;
private long finalizeTime; private long finalizeTime;
private boolean createdRollbackImages; private boolean createdRollbackImages;
public RollingUpgradeInfo(String blockPoolId, boolean createdRollbackImages, public RollingUpgradeInfo(String blockPoolId, boolean createdRollbackImages,
long startTime, long finalizeTime) { long startTime, long finalizeTime) {
super(blockPoolId, finalizeTime != 0); super(blockPoolId, finalizeTime != 0);
@ -39,7 +39,7 @@ public class RollingUpgradeInfo extends RollingUpgradeStatus {
this.startTime = startTime; this.startTime = startTime;
this.finalizeTime = finalizeTime; this.finalizeTime = finalizeTime;
} }
public boolean createdRollbackImages() { public boolean createdRollbackImages() {
return createdRollbackImages; return createdRollbackImages;
} }
@ -51,7 +51,7 @@ public class RollingUpgradeInfo extends RollingUpgradeStatus {
public boolean isStarted() { public boolean isStarted() {
return startTime != 0; return startTime != 0;
} }
/** @return The rolling upgrade starting time. */ /** @return The rolling upgrade starting time. */
public long getStartTime() { public long getStartTime() {
return startTime; return startTime;
@ -102,7 +102,7 @@ public class RollingUpgradeInfo extends RollingUpgradeStatus {
+ "\n Start Time: " + (startTime == 0? "<NOT STARTED>": timestamp2String(startTime)) + "\n Start Time: " + (startTime == 0? "<NOT STARTED>": timestamp2String(startTime))
+ "\n Finalize Time: " + (finalizeTime == 0? "<NOT FINALIZED>": timestamp2String(finalizeTime)); + "\n Finalize Time: " + (finalizeTime == 0? "<NOT FINALIZED>": timestamp2String(finalizeTime));
} }
private static String timestamp2String(long timestamp) { private static String timestamp2String(long timestamp) {
return new Date(timestamp) + " (=" + timestamp + ")"; return new Date(timestamp) + " (=" + timestamp + ")";
} }

View File

@ -31,7 +31,7 @@ public class DataEncryptionKey {
public final byte[] encryptionKey; public final byte[] encryptionKey;
public final long expiryDate; public final long expiryDate;
public final String encryptionAlgorithm; public final String encryptionAlgorithm;
public DataEncryptionKey(int keyId, String blockPoolId, byte[] nonce, public DataEncryptionKey(int keyId, String blockPoolId, byte[] nonce,
byte[] encryptionKey, long expiryDate, String encryptionAlgorithm) { byte[] encryptionKey, long expiryDate, String encryptionAlgorithm) {
this.keyId = keyId; this.keyId = keyId;
@ -41,7 +41,7 @@ public class DataEncryptionKey {
this.expiryDate = expiryDate; this.expiryDate = expiryDate;
this.encryptionAlgorithm = encryptionAlgorithm; this.encryptionAlgorithm = encryptionAlgorithm;
} }
@Override @Override
public String toString() { public String toString() {
return keyId + "/" + blockPoolId + "/" + nonce.length + "/" + return keyId + "/" + blockPoolId + "/" + nonce.length + "/" +

View File

@ -140,6 +140,9 @@ Release 2.8.0 - UNRELEASED
HDFS-8185. Separate client related routines in HAUtil into a new class. HDFS-8185. Separate client related routines in HAUtil into a new class.
(wheat9) (wheat9)
HDFS-8218. Move classes that used by ClientProtocol into hdfs-client.
(wheat9)
OPTIMIZATIONS OPTIMIZATIONS
HDFS-8026. Trace FSOutputSummer#writeChecksumChunks rather than HDFS-8026. Trace FSOutputSummer#writeChecksumChunks rather than