Evict resources from resource pool after timeout
[chromium-blink-merge.git] / net / socket / stream_socket.cc
blob650f388f6922cb9b35b54233dd9f23707f2f3c2f
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "net/socket/stream_socket.h"
7 #include "base/metrics/field_trial.h"
8 #include "base/metrics/histogram_macros.h"
9 #include "base/strings/string_number_conversions.h"
10 #include "base/values.h"
12 namespace net {
14 StreamSocket::UseHistory::UseHistory()
15 : was_ever_connected_(false),
16 was_used_to_convey_data_(false),
17 omnibox_speculation_(false),
18 subresource_speculation_(false) {
21 StreamSocket::UseHistory::~UseHistory() {
22 EmitPreconnectionHistograms();
25 void StreamSocket::UseHistory::Reset() {
26 EmitPreconnectionHistograms();
27 was_ever_connected_ = false;
28 was_used_to_convey_data_ = false;
29 // omnibox_speculation_ and subresource_speculation_ values
30 // are intentionally preserved.
33 void StreamSocket::UseHistory::set_was_ever_connected() {
34 DCHECK(!was_used_to_convey_data_);
35 was_ever_connected_ = true;
38 void StreamSocket::UseHistory::set_was_used_to_convey_data() {
39 DCHECK(was_ever_connected_);
40 was_used_to_convey_data_ = true;
44 void StreamSocket::UseHistory::set_subresource_speculation() {
45 DCHECK(was_ever_connected_);
46 // TODO(jar): We should transition to marking a socket (or stream) at
47 // construction time as being created for speculative reasons. This current
48 // approach of trying to track use of a socket to convey data can make
49 // mistakes when other sockets (such as ones sitting in the pool for a long
50 // time) are issued. Unused sockets can be left over when a when a set of
51 // connections to a host are made, and one is "unlucky" and takes so long to
52 // complete a connection, that another socket is used, and recycled before a
53 // second connection comes available. Similarly, re-try connections can leave
54 // an original (slow to connect socket) in the pool, and that can be issued
55 // to a speculative requester. In any cases such old sockets will fail when an
56 // attempt is made to used them!... and then it will look like a speculative
57 // socket was discarded without any user!?!?!
58 if (was_used_to_convey_data_)
59 return;
60 subresource_speculation_ = true;
63 void StreamSocket::UseHistory::set_omnibox_speculation() {
64 DCHECK(was_ever_connected_);
65 if (was_used_to_convey_data_)
66 return;
67 omnibox_speculation_ = true;
70 bool StreamSocket::UseHistory::was_used_to_convey_data() const {
71 DCHECK(!was_used_to_convey_data_ || was_ever_connected_);
72 return was_used_to_convey_data_;
75 void StreamSocket::UseHistory::EmitPreconnectionHistograms() const {
76 DCHECK(!subresource_speculation_ || !omnibox_speculation_);
77 // 0 ==> non-speculative, never connected.
78 // 1 ==> non-speculative never used (but connected).
79 // 2 ==> non-speculative and used.
80 // 3 ==> omnibox_speculative never connected.
81 // 4 ==> omnibox_speculative never used (but connected).
82 // 5 ==> omnibox_speculative and used.
83 // 6 ==> subresource_speculative never connected.
84 // 7 ==> subresource_speculative never used (but connected).
85 // 8 ==> subresource_speculative and used.
86 int result;
87 if (was_used_to_convey_data_)
88 result = 2;
89 else if (was_ever_connected_)
90 result = 1;
91 else
92 result = 0; // Never used, and not really connected.
94 if (omnibox_speculation_)
95 result += 3;
96 else if (subresource_speculation_)
97 result += 6;
98 UMA_HISTOGRAM_ENUMERATION("Net.PreconnectUtilization2", result, 9);
101 } // namespace net