Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(260)

Side by Side Diff: sql/connection.cc

Issue 1316493006: [sql] Record SQLite memory usage after a week. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | tools/metrics/histograms/histograms.xml » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "sql/connection.h" 5 #include "sql/connection.h"
6 6
7 #include <string.h> 7 #include <string.h>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/files/file_path.h" 10 #include "base/files/file_path.h"
(...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after
121 void RecordSqliteMemoryHour() { 121 void RecordSqliteMemoryHour() {
122 const int64 used = sqlite3_memory_used(); 122 const int64 used = sqlite3_memory_used();
123 UMA_HISTOGRAM_COUNTS("Sqlite.MemoryKB.OneHour", used / 1024); 123 UMA_HISTOGRAM_COUNTS("Sqlite.MemoryKB.OneHour", used / 1024);
124 } 124 }
125 125
126 void RecordSqliteMemoryDay() { 126 void RecordSqliteMemoryDay() {
127 const int64 used = sqlite3_memory_used(); 127 const int64 used = sqlite3_memory_used();
128 UMA_HISTOGRAM_COUNTS("Sqlite.MemoryKB.OneDay", used / 1024); 128 UMA_HISTOGRAM_COUNTS("Sqlite.MemoryKB.OneDay", used / 1024);
129 } 129 }
130 130
131 void RecordSqliteMemoryWeek() {
132 const int64 used = sqlite3_memory_used();
133 UMA_HISTOGRAM_COUNTS("Sqlite.MemoryKB.OneWeek", used / 1024);
134 }
135
131 // SQLite automatically calls sqlite3_initialize() lazily, but 136 // SQLite automatically calls sqlite3_initialize() lazily, but
132 // sqlite3_initialize() uses double-checked locking and thus can have 137 // sqlite3_initialize() uses double-checked locking and thus can have
133 // data races. 138 // data races.
134 // 139 //
135 // TODO(shess): Another alternative would be to have 140 // TODO(shess): Another alternative would be to have
136 // sqlite3_initialize() called as part of process bring-up. If this 141 // sqlite3_initialize() called as part of process bring-up. If this
137 // is changed, remove the dynamic_annotations dependency in sql.gyp. 142 // is changed, remove the dynamic_annotations dependency in sql.gyp.
138 base::LazyInstance<base::Lock>::Leaky 143 base::LazyInstance<base::Lock>::Leaky
139 g_sqlite_init_lock = LAZY_INSTANCE_INITIALIZER; 144 g_sqlite_init_lock = LAZY_INSTANCE_INITIALIZER;
140 void InitializeSqlite() { 145 void InitializeSqlite() {
141 base::AutoLock lock(g_sqlite_init_lock.Get()); 146 base::AutoLock lock(g_sqlite_init_lock.Get());
142 static bool first_call = true; 147 static bool first_call = true;
143 if (first_call) { 148 if (first_call) {
144 sqlite3_initialize(); 149 sqlite3_initialize();
145 150
146 // Schedule callback to record memory footprint histograms at 10m, 1h, and 151 // Schedule callback to record memory footprint histograms at 10m, 1h, and
147 // 1d. There may not be a message loop in tests. 152 // 1d. There may not be a message loop in tests.
148 if (base::MessageLoop::current()) { 153 if (base::MessageLoop::current()) {
149 base::MessageLoop::current()->PostDelayedTask( 154 base::MessageLoop::current()->PostDelayedTask(
150 FROM_HERE, base::Bind(&RecordSqliteMemory10Min), 155 FROM_HERE, base::Bind(&RecordSqliteMemory10Min),
151 base::TimeDelta::FromMinutes(10)); 156 base::TimeDelta::FromMinutes(10));
152 base::MessageLoop::current()->PostDelayedTask( 157 base::MessageLoop::current()->PostDelayedTask(
153 FROM_HERE, base::Bind(&RecordSqliteMemoryHour), 158 FROM_HERE, base::Bind(&RecordSqliteMemoryHour),
154 base::TimeDelta::FromHours(1)); 159 base::TimeDelta::FromHours(1));
155 base::MessageLoop::current()->PostDelayedTask( 160 base::MessageLoop::current()->PostDelayedTask(
156 FROM_HERE, base::Bind(&RecordSqliteMemoryDay), 161 FROM_HERE, base::Bind(&RecordSqliteMemoryDay),
157 base::TimeDelta::FromDays(1)); 162 base::TimeDelta::FromDays(1));
163 base::MessageLoop::current()->PostDelayedTask(
164 FROM_HERE, base::Bind(&RecordSqliteMemoryWeek),
165 base::TimeDelta::FromDays(7));
158 } 166 }
159 167
160 first_call = false; 168 first_call = false;
161 } 169 }
162 } 170 }
163 171
164 // Helper to get the sqlite3_file* associated with the "main" database. 172 // Helper to get the sqlite3_file* associated with the "main" database.
165 int GetSqlite3File(sqlite3* db, sqlite3_file** file) { 173 int GetSqlite3File(sqlite3* db, sqlite3_file** file) {
166 *file = NULL; 174 *file = NULL;
167 int rc = sqlite3_file_control(db, NULL, SQLITE_FCNTL_FILE_POINTER, file); 175 int rc = sqlite3_file_control(db, NULL, SQLITE_FCNTL_FILE_POINTER, file);
(...skipping 1206 matching lines...) Expand 10 before | Expand all | Expand 10 after
1374 ignore_result(Execute(kNoWritableSchema)); 1382 ignore_result(Execute(kNoWritableSchema));
1375 1383
1376 return ret; 1384 return ret;
1377 } 1385 }
1378 1386
1379 base::TimeTicks TimeSource::Now() { 1387 base::TimeTicks TimeSource::Now() {
1380 return base::TimeTicks::Now(); 1388 return base::TimeTicks::Now();
1381 } 1389 }
1382 1390
1383 } // namespace sql 1391 } // namespace sql
OLDNEW
« no previous file with comments | « no previous file | tools/metrics/histograms/histograms.xml » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698