summaryrefslogtreecommitdiffstats
path: root/net/base
diff options
context:
space:
mode:
authormbelshe@google.com <mbelshe@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-17 21:28:06 +0000
committermbelshe@google.com <mbelshe@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-17 21:28:06 +0000
commit4a324a1705813d626833e38539f3cc3bf27b2627 (patch)
tree306d0b3badab4db10da858b4895f35c592d114d5 /net/base
parent4f2338e7a436d508d031639a3dcd88d36272b78d (diff)
downloadchromium_src-4a324a1705813d626833e38539f3cc3bf27b2627.zip
chromium_src-4a324a1705813d626833e38539f3cc3bf27b2627.tar.gz
chromium_src-4a324a1705813d626833e38539f3cc3bf27b2627.tar.bz2
Increase socket buffer size from default (8KB) to 64KB.
Using a XMLHttpRequest benchmark to download 3MB files, this change contributed ~30% performance boost. Review URL: http://codereview.chromium.org/7426 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3566 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/base')
-rw-r--r--net/base/tcp_client_socket.cc45
1 files changed, 45 insertions, 0 deletions
diff --git a/net/base/tcp_client_socket.cc b/net/base/tcp_client_socket.cc
index 185902e..d42cf1b 100644
--- a/net/base/tcp_client_socket.cc
+++ b/net/base/tcp_client_socket.cc
@@ -219,6 +219,51 @@ int TCPClientSocket::CreateSocket(const struct addrinfo* ai) {
LOG(ERROR) << "WSASocket failed: " << err;
return MapWinsockError(err);
}
+
+ // Increase the socket buffer sizes from the default sizes.
+ // In performance testing, there is substantial benefit by increasing
+ // from 8KB to 32KB. I tested 64, 128, and 256KB as well, but did not
+ // see additional performance benefit (will be network dependent).
+ // See also:
+ // http://support.microsoft.com/kb/823764/EN-US
+ // On XP, the default buffer sizes are 8KB.
+ const int kSocketBufferSize = 32 * 1024;
+ int rv = setsockopt(socket_, SOL_SOCKET, SO_SNDBUF,
+ reinterpret_cast<const char*>(&kSocketBufferSize),
+ sizeof(kSocketBufferSize));
+ DCHECK(!rv) << "Could not set socket send buffer size";
+ rv = setsockopt(socket_, SOL_SOCKET, SO_RCVBUF,
+ reinterpret_cast<const char*>(&kSocketBufferSize),
+ sizeof(kSocketBufferSize));
+ DCHECK(!rv) << "Could not set socket receive buffer size";
+
+ // Disable Nagle.
+ // The Nagle implementation on windows is governed by RFC 896. The idea
+ // behind Nagle is to reduce small packets on the network. When Nagle is
+ // enabled, if a partial packet has been sent, the TCP stack will disallow
+ // further *partial* packets until an ACK has been received from the other
+ // side. Good applications should always strive to send as much data as
+ // possible and avoid partial-packet sends. However, in most real world
+ // applications, there are edge cases where this does not happen, and two
+ // partil packets may be sent back to back. For a browser, it is NEVER
+ // a benefit to delay for an RTT before the second packet is sent.
+ //
+ // As a practical example in Chromium today, consider the case of a small
+ // POST. I have verified this:
+ // Client writes 649 bytes of header (partial packet #1)
+ // Client writes 50 bytes of POST data (partial packet #2)
+ // In the above example, with Nagle, a RTT delay is inserted between these
+ // two sends due to nagle. RTTs can easily be 100ms or more. The best
+ // fix is to make sure that for POSTing data, we write as much data as
+ // possible and minimize partial packets. We will fix that. But disabling
+ // Nagle also ensure we don't run into this delay in other edge cases.
+ // See also:
+ // http://technet.microsoft.com/en-us/library/bb726981.aspx
+ const BOOL kDisableNagle = TRUE;
+ rv = setsockopt(socket_, IPPROTO_TCP, TCP_NODELAY,
+ reinterpret_cast<const char*>(&kDisableNagle), sizeof(kDisableNagle));
+ DCHECK(!rv) << "Could not disable nagle";
+
return OK;
}