Support SSH ZLib Compression
In the general case, we want to disable transparent compression, since the majority of our data transfer is highly compressed Git pack files and we cannot make them any smaller than they already are. However, if there are CPU in abundance and the server is reachable through slow networks; gits with huge amount of refs can benefit from SSH-compression since git does not compress the ref announcement during the handshake. Compression can be especially useful when Gerrit slaves are being used for the larger clones and fetches and the master server mostly takes small receive-packs. To enable compression use sshd.enableCompression in gerrit.config. Change-Id: I7ff9efd26e746db5f1400017816984d652585008
This commit is contained in:
parent
c7eb9fc190
commit
d60e90f714
@ -3289,6 +3289,23 @@ namespace. To alias `replication start` to `gerrit replicate`:
|
|||||||
[[sshd]]
|
[[sshd]]
|
||||||
=== Section sshd
|
=== Section sshd
|
||||||
|
|
||||||
|
[[sshd.enableCompression]]sshd.enableCompression::
|
||||||
|
+
|
||||||
|
In the general case, we want to disable transparent compression, since
|
||||||
|
the majority of our data transfer is highly compressed Git pack files
|
||||||
|
and we cannot make them any smaller than they already are.
|
||||||
|
+
|
||||||
|
However, if there are CPU in abundance and the server is reachable
|
||||||
|
through slow networks, gits with huge amount of refs can benefit from
|
||||||
|
SSH-compression since git does not compress the ref announcement during
|
||||||
|
handshake.
|
||||||
|
+
|
||||||
|
Compression can be especially useful when Gerrit slaves are being used
|
||||||
|
for the larger clones and fetches and the master server mostly takes
|
||||||
|
small receive-packs.
|
||||||
|
+
|
||||||
|
By default, `false`.
|
||||||
|
|
||||||
[[sshd.backend]]sshd.backend::
|
[[sshd.backend]]sshd.backend::
|
||||||
+
|
+
|
||||||
Starting from version 0.9.0 Apache SSHD project added support for NIO2
|
Starting from version 0.9.0 Apache SSHD project added support for NIO2
|
||||||
|
@ -61,6 +61,7 @@ import org.apache.sshd.common.cipher.BlowfishCBC;
|
|||||||
import org.apache.sshd.common.cipher.CipherNone;
|
import org.apache.sshd.common.cipher.CipherNone;
|
||||||
import org.apache.sshd.common.cipher.TripleDESCBC;
|
import org.apache.sshd.common.cipher.TripleDESCBC;
|
||||||
import org.apache.sshd.common.compression.CompressionNone;
|
import org.apache.sshd.common.compression.CompressionNone;
|
||||||
|
import org.apache.sshd.common.compression.CompressionZlib;
|
||||||
import org.apache.sshd.common.file.FileSystemFactory;
|
import org.apache.sshd.common.file.FileSystemFactory;
|
||||||
import org.apache.sshd.common.file.FileSystemView;
|
import org.apache.sshd.common.file.FileSystemView;
|
||||||
import org.apache.sshd.common.file.SshFile;
|
import org.apache.sshd.common.file.SshFile;
|
||||||
@ -216,6 +217,9 @@ public class SshDaemon extends SshServer implements SshInfo, LifecycleListener {
|
|||||||
final String kerberosPrincipal = cfg.getString(
|
final String kerberosPrincipal = cfg.getString(
|
||||||
"sshd", null, "kerberosPrincipal");
|
"sshd", null, "kerberosPrincipal");
|
||||||
|
|
||||||
|
final boolean enableCompression = cfg.getBoolean(
|
||||||
|
"sshd", "enableCompression", false);
|
||||||
|
|
||||||
SshSessionBackend backend = cfg.getEnum(
|
SshSessionBackend backend = cfg.getEnum(
|
||||||
"sshd", null, "backend", SshSessionBackend.MINA);
|
"sshd", null, "backend", SshSessionBackend.MINA);
|
||||||
|
|
||||||
@ -236,7 +240,7 @@ public class SshDaemon extends SshServer implements SshInfo, LifecycleListener {
|
|||||||
initForwarding();
|
initForwarding();
|
||||||
initFileSystemFactory();
|
initFileSystemFactory();
|
||||||
initSubsystems();
|
initSubsystems();
|
||||||
initCompression();
|
initCompression(enableCompression);
|
||||||
initUserAuth(userAuth, kerberosAuth, kerberosKeytab, kerberosPrincipal);
|
initUserAuth(userAuth, kerberosAuth, kerberosKeytab, kerberosPrincipal);
|
||||||
setKeyPairProvider(hostKeyProvider);
|
setKeyPairProvider(hostKeyProvider);
|
||||||
setCommandFactory(commandFactory);
|
setCommandFactory(commandFactory);
|
||||||
@ -594,13 +598,30 @@ public class SshDaemon extends SshServer implements SshInfo, LifecycleListener {
|
|||||||
new SignatureECDSA.NISTP521Factory()));
|
new SignatureECDSA.NISTP521Factory()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initCompression() {
|
private void initCompression(boolean enableCompression) {
|
||||||
// Always disable transparent compression. The majority of our data
|
List<NamedFactory<Compression>> compressionFactories =
|
||||||
// transfer is highly compressed Git pack files. We cannot make them
|
Lists.newArrayList();
|
||||||
// any smaller than they already are.
|
|
||||||
|
// Always support no compression over SSHD.
|
||||||
|
compressionFactories.add(new CompressionNone.Factory());
|
||||||
|
|
||||||
|
// In the general case, we want to disable transparent compression, since
|
||||||
|
// the majority of our data transfer is highly compressed Git pack files
|
||||||
|
// and we cannot make them any smaller than they already are.
|
||||||
//
|
//
|
||||||
setCompressionFactories(Arrays
|
// However, if there are CPU in abundance and the server is reachable through
|
||||||
.<NamedFactory<Compression>> asList(new CompressionNone.Factory()));
|
// slow networks, gits with huge amount of refs can benefit from SSH-compression
|
||||||
|
// since git does not compress the ref announcement during the handshake.
|
||||||
|
//
|
||||||
|
// Compression can be especially useful when Gerrit slaves are being used
|
||||||
|
// for the larger clones and fetches and the master server mostly takes small
|
||||||
|
// receive-packs.
|
||||||
|
|
||||||
|
if (enableCompression) {
|
||||||
|
compressionFactories.add(new CompressionZlib.Factory());
|
||||||
|
}
|
||||||
|
|
||||||
|
setCompressionFactories(compressionFactories);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initChannels() {
|
private void initChannels() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user