diff options
author | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-29 01:04:06 +0000 |
---|---|---|
committer | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-29 01:04:06 +0000 |
commit | 2d731a343fb695b7bf2c83ac7ddc0d1154a42586 (patch) | |
tree | 9beadc55993765f8973cfd40cb6c3aaf61de7047 /net/spdy/spdy_network_transaction.cc | |
parent | b861e4eb19ba6d189e40fe4fb5f3c9d9b461a5f4 (diff) | |
download | chromium_src-2d731a343fb695b7bf2c83ac7ddc0d1154a42586.zip chromium_src-2d731a343fb695b7bf2c83ac7ddc0d1154a42586.tar.gz chromium_src-2d731a343fb695b7bf2c83ac7ddc0d1154a42586.tar.bz2 |
Implement a 15 connection per proxy server limit.
Previously, we had a limit of 6 connections per proxy server, which was horrifically low.
Connections to all endpoint hosts remains at 6.
Basically, we have a map of socket pools, keyed by the proxy server.
Each of these proxy socket pools has a socket limit of 15 and a connection limit per host of 6.
The main TCP socket pool (non-proxied) has the standard 256 socket limit, and connection limit per host of 6.
There are two maps currently, one for HTTP proxies and one for SOCKS proxies.
Note that SSL tunnels over HTTP CONNECTs are still located within the standard http proxy socket pools.
We depend on the fact that our code never returns a non-SSL connected socket to the pool for a |connection_group|
that is to a HTTPS endpoint. A newly connected socket from the pool will only have the TCP connection done. An
idle socket will have both the TCP and the HTTP CONNECT and the SSL handshake done for it.
TODO(willchan): Remove the extra constructor overload for the old deprecated parameters. Switch to using HostPortPair everywhere.
TODO(willchan): Finish SSL socket pools.
TODO(willchan): Rip out the DoInitConnection() code so it can be shared by other caller (TCP pre-warming!).
TODO(willchan): Flush out the socket pool maps when the proxy configuration changes.
TODO(willchan): Fix up global socket limits. They're slightly broken in this case, since each pool instance has its own "global" limit, so obviously different pools don't share the same "global" limit. This is such a minor deal since the global limits are so small for proxy servers compared to the system global limits (256 vs 15), that it doesn't have a big effect.
TODO(willchan): Drink moar b33r.
BUG=12066
Review URL: http://codereview.chromium.org/1808001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@45896 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/spdy/spdy_network_transaction.cc')
-rw-r--r-- | net/spdy/spdy_network_transaction.cc | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/spdy/spdy_network_transaction.cc b/net/spdy/spdy_network_transaction.cc index 6a50fb2..b0f35af 100644 --- a/net/spdy/spdy_network_transaction.cc +++ b/net/spdy/spdy_network_transaction.cc @@ -225,9 +225,9 @@ int SpdyNetworkTransaction::DoInitConnection() { std::string connection_group = "spdy."; connection_group.append(host); - TCPSocketParams tcp_params(host, port, request_->priority, request_->referrer, - false); HostPortPair host_port_pair(host, port); + TCPSocketParams tcp_params(host_port_pair, request_->priority, + request_->referrer, false); spdy_ = session_->spdy_session_pool()->Get(host_port_pair, session_); DCHECK(spdy_); |