HDFS-9557. Reduce object allocation in PB conversion. Contributed by Daryn Sharp.

(cherry picked from commit c470c8953d)
(cherry picked from commit e8e3737ce8)
This commit is contained in:
cnauroth 2015-12-16 10:45:32 -08:00
parent c4febc7d02
commit d3e1161b8d
4 changed files with 26 additions and 15 deletions

View File

@ -189,7 +189,8 @@ public class PBHelperClient {
} }
public static ByteString getByteString(byte[] bytes) { public static ByteString getByteString(byte[] bytes) {
return ByteString.copyFrom(bytes); // return singleton to reduce object allocation
return (bytes.length == 0) ? ByteString.EMPTY : ByteString.copyFrom(bytes);
} }
public static ShmId convert(ShortCircuitShmIdProto shmId) { public static ShmId convert(ShortCircuitShmIdProto shmId) {
@ -216,8 +217,8 @@ public class PBHelperClient {
public static TokenProto convert(Token<?> tok) { public static TokenProto convert(Token<?> tok) {
return TokenProto.newBuilder(). return TokenProto.newBuilder().
setIdentifier(ByteString.copyFrom(tok.getIdentifier())). setIdentifier(getByteString(tok.getIdentifier())).
setPassword(ByteString.copyFrom(tok.getPassword())). setPassword(getByteString(tok.getPassword())).
setKind(tok.getKind().toString()). setKind(tok.getKind().toString()).
setService(tok.getService().toString()).build(); setService(tok.getService().toString()).build();
} }
@ -446,16 +447,16 @@ public class PBHelperClient {
builder.setSuite(convert(option.getCipherSuite())); builder.setSuite(convert(option.getCipherSuite()));
} }
if (option.getInKey() != null) { if (option.getInKey() != null) {
builder.setInKey(ByteString.copyFrom(option.getInKey())); builder.setInKey(getByteString(option.getInKey()));
} }
if (option.getInIv() != null) { if (option.getInIv() != null) {
builder.setInIv(ByteString.copyFrom(option.getInIv())); builder.setInIv(getByteString(option.getInIv()));
} }
if (option.getOutKey() != null) { if (option.getOutKey() != null) {
builder.setOutKey(ByteString.copyFrom(option.getOutKey())); builder.setOutKey(getByteString(option.getOutKey()));
} }
if (option.getOutIv() != null) { if (option.getOutIv() != null) {
builder.setOutIv(ByteString.copyFrom(option.getOutIv())); builder.setOutIv(getByteString(option.getOutIv()));
} }
return builder.build(); return builder.build();
} }
@ -1676,8 +1677,8 @@ public class PBHelperClient {
DataEncryptionKeyProto.Builder b = DataEncryptionKeyProto.newBuilder() DataEncryptionKeyProto.Builder b = DataEncryptionKeyProto.newBuilder()
.setKeyId(bet.keyId) .setKeyId(bet.keyId)
.setBlockPoolId(bet.blockPoolId) .setBlockPoolId(bet.blockPoolId)
.setNonce(ByteString.copyFrom(bet.nonce)) .setNonce(getByteString(bet.nonce))
.setEncryptionKey(ByteString.copyFrom(bet.encryptionKey)) .setEncryptionKey(getByteString(bet.encryptionKey))
.setExpiryDate(bet.expiryDate); .setExpiryDate(bet.expiryDate);
if (bet.encryptionAlgorithm != null) { if (bet.encryptionAlgorithm != null) {
b.setEncryptionAlgorithm(bet.encryptionAlgorithm); b.setEncryptionAlgorithm(bet.encryptionAlgorithm);
@ -1754,10 +1755,10 @@ public class PBHelperClient {
setGroup(fs.getGroup()). setGroup(fs.getGroup()).
setFileId(fs.getFileId()). setFileId(fs.getFileId()).
setChildrenNum(fs.getChildrenNum()). setChildrenNum(fs.getChildrenNum()).
setPath(ByteString.copyFrom(fs.getLocalNameInBytes())). setPath(getByteString(fs.getLocalNameInBytes())).
setStoragePolicy(fs.getStoragePolicy()); setStoragePolicy(fs.getStoragePolicy());
if (fs.isSymlink()) { if (fs.isSymlink()) {
builder.setSymlink(ByteString.copyFrom(fs.getSymlinkInBytes())); builder.setSymlink(getByteString(fs.getSymlinkInBytes()));
} }
if (fs.getFileEncryptionInfo() != null) { if (fs.getFileEncryptionInfo() != null) {
builder.setFileEncryptionInfo(convert(fs.getFileEncryptionInfo())); builder.setFileEncryptionInfo(convert(fs.getFileEncryptionInfo()));
@ -1780,7 +1781,7 @@ public class PBHelperClient {
int snapshotNumber = status.getSnapshotNumber(); int snapshotNumber = status.getSnapshotNumber();
int snapshotQuota = status.getSnapshotQuota(); int snapshotQuota = status.getSnapshotQuota();
byte[] parentFullPath = status.getParentFullPath(); byte[] parentFullPath = status.getParentFullPath();
ByteString parentFullPathBytes = ByteString.copyFrom( ByteString parentFullPathBytes = getByteString(
parentFullPath == null ? DFSUtilClient.EMPTY_BYTES : parentFullPath); parentFullPath == null ? DFSUtilClient.EMPTY_BYTES : parentFullPath);
HdfsFileStatusProto fs = convert(status.getDirStatus()); HdfsFileStatusProto fs = convert(status.getDirStatus());
SnapshottableDirectoryStatusProto.Builder builder = SnapshottableDirectoryStatusProto.Builder builder =
@ -1995,7 +1996,7 @@ public class PBHelperClient {
if (entry == null) { if (entry == null) {
return null; return null;
} }
ByteString sourcePath = ByteString.copyFrom(entry.getSourcePath() == null ? ByteString sourcePath = getByteString(entry.getSourcePath() == null ?
DFSUtilClient.EMPTY_BYTES : entry.getSourcePath()); DFSUtilClient.EMPTY_BYTES : entry.getSourcePath());
String modification = entry.getType().getLabel(); String modification = entry.getType().getLabel();
SnapshotDiffReportEntryProto.Builder builder = SnapshotDiffReportEntryProto SnapshotDiffReportEntryProto.Builder builder = SnapshotDiffReportEntryProto
@ -2003,7 +2004,7 @@ public class PBHelperClient {
.setModificationLabel(modification); .setModificationLabel(modification);
if (entry.getType() == DiffType.RENAME) { if (entry.getType() == DiffType.RENAME) {
ByteString targetPath = ByteString targetPath =
ByteString.copyFrom(entry.getTargetPath() == null ? getByteString(entry.getTargetPath() == null ?
DFSUtilClient.EMPTY_BYTES : entry.getTargetPath()); DFSUtilClient.EMPTY_BYTES : entry.getTargetPath());
builder.setTargetPath(targetPath); builder.setTargetPath(targetPath);
} }

View File

@ -859,6 +859,9 @@ Release 2.8.0 - UNRELEASED
HDFS-8894. Set SO_KEEPALIVE on DN server sockets. HDFS-8894. Set SO_KEEPALIVE on DN server sockets.
(Kanaka Kumar Avvaru via wang) (Kanaka Kumar Avvaru via wang)
HDFS-9557. Reduce object allocation in PB conversion
(Daryn Sharp via cnauroth)
OPTIMIZATIONS OPTIMIZATIONS
HDFS-8026. Trace FSOutputSummer#writeChecksumChunks rather than HDFS-8026. Trace FSOutputSummer#writeChecksumChunks rather than

View File

@ -209,7 +209,7 @@ public class PBHelper {
public static BlockKeyProto convert(BlockKey key) { public static BlockKeyProto convert(BlockKey key) {
byte[] encodedKey = key.getEncodedKey(); byte[] encodedKey = key.getEncodedKey();
ByteString keyBytes = ByteString.copyFrom(encodedKey == null ? ByteString keyBytes = PBHelperClient.getByteString(encodedKey == null ?
DFSUtilClient.EMPTY_BYTES : encodedKey); DFSUtilClient.EMPTY_BYTES : encodedKey);
return BlockKeyProto.newBuilder().setKeyId(key.getKeyId()) return BlockKeyProto.newBuilder().setKeyId(key.getKeyId())
.setKeyBytes(keyBytes).setExpiryDate(key.getExpiryDate()).build(); .setKeyBytes(keyBytes).setExpiryDate(key.getExpiryDate()).build();

View File

@ -19,6 +19,7 @@ package org.apache.hadoop.hdfs.protocolPB;
import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.CoreMatchers.is;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertSame;
import static org.junit.Assert.assertThat; import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -89,6 +90,7 @@ import org.junit.Test;
import com.google.common.base.Joiner; import com.google.common.base.Joiner;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.protobuf.ByteString;
/** /**
* Tests for {@link PBHelper} * Tests for {@link PBHelper}
@ -100,6 +102,11 @@ public class TestPBHelper {
*/ */
private static final double DELTA = 0.000001; private static final double DELTA = 0.000001;
@Test
public void testGetByteString() {
assertSame(ByteString.EMPTY, PBHelperClient.getByteString(new byte[0]));
}
@Test @Test
public void testConvertNamenodeRole() { public void testConvertNamenodeRole() {
assertEquals(NamenodeRoleProto.BACKUP, assertEquals(NamenodeRoleProto.BACKUP,