diff options
author | mbelshe@google.com <mbelshe@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-17 21:28:06 +0000 |
---|---|---|
committer | mbelshe@google.com <mbelshe@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-17 21:28:06 +0000 |
commit | 4a324a1705813d626833e38539f3cc3bf27b2627 (patch) | |
tree | 306d0b3badab4db10da858b4895f35c592d114d5 /net/base | |
parent | 4f2338e7a436d508d031639a3dcd88d36272b78d (diff) | |
download | chromium_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.cc | 45 |
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; } |