HDFS-9557. Reduce object allocation in PB conversion. Contributed by Daryn Sharp.
(cherry picked from commitc470c8953d
) (cherry picked from commite8e3737ce8
)
This commit is contained in:
parent
c4febc7d02
commit
d3e1161b8d
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in New Issue