summaryrefslogtreecommitdiff
path: root/src/third_party/wiredtiger/src/include/os_fhandle.i
diff options
context:
space:
mode:
authorLuke Chen <luke.chen@mongodb.com>2018-01-05 22:07:41 +1100
committerLuke Chen <luke.chen@mongodb.com>2018-01-05 22:07:41 +1100
commitbd9ed5bbe07754221ad014dceefc0ebdb0ecab32 (patch)
tree622a3cc94249954a7bf0757231c40792c9ef5378 /src/third_party/wiredtiger/src/include/os_fhandle.i
parent2158ea8d6c84c9a68b50f76c9dd23b8a193b65f8 (diff)
downloadmongo-bd9ed5bbe07754221ad014dceefc0ebdb0ecab32.tar.gz
Import wiredtiger: 9e5044823185feffa71e56a6593cfb92e0741a41 from branch mongodb-3.8
ref: 1a29eac4dc..9e50448231 for: 3.7.1 WT-2705 High throughput cache bound many threaded workloads can experience long latencies WT-3725 Add statistics to locks around timestamp structures WT-3750 Fast-path fs_directory_list of a single file. WT-3768 Lookaside optimization: birthmarks WT-3769 Fix a bug in reverse cursor walks with particular delete patterns and prefix compression enabled WT-3779 Add support for string formats with WT_CURSOR::modify WT-3800 test_wt2834_join_bloom_fix hang WT-3806 Make sure rdtsc values move forward in time WT-3807 clang static analysis updates WT-3810 wt_rdtsc calibration needs to be longer and verify validity WT-3812 debugging page output should handle complex key/value items. WT-3816 Enable prefix compression on the lookaside table WT-3819 clang static analysis improvements WT-3820 Add a WT_SESSION.breakpoint method for Python debugging. WT-3822 Update WiredTiger copyrights to 2018 WT-3824 tsc_nsec_ratio can compute to zero and cause divide by zero bug
Diffstat (limited to 'src/third_party/wiredtiger/src/include/os_fhandle.i')
-rw-r--r--src/third_party/wiredtiger/src/include/os_fhandle.i19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/third_party/wiredtiger/src/include/os_fhandle.i b/src/third_party/wiredtiger/src/include/os_fhandle.i
index e5177e64b57..5685b0f46dc 100644
--- a/src/third_party/wiredtiger/src/include/os_fhandle.i
+++ b/src/third_party/wiredtiger/src/include/os_fhandle.i
@@ -1,5 +1,5 @@
/*-
- * Copyright (c) 2014-2017 MongoDB, Inc.
+ * Copyright (c) 2014-2018 MongoDB, Inc.
* Copyright (c) 2008-2014 WiredTiger, Inc.
* All rights reserved.
*
@@ -7,6 +7,13 @@
*/
/*
+ * Define functions that increment histogram statistics for filesystem
+ * operations latency.
+ */
+WT_STAT_MSECS_HIST_INCR_FUNC(fsread, perf_hist_fsread_latency, 10)
+WT_STAT_MSECS_HIST_INCR_FUNC(fswrite, perf_hist_fswrite_latency, 10)
+
+/*
* __wt_fsync --
* POSIX fsync.
*/
@@ -94,6 +101,7 @@ __wt_read(
WT_SESSION_IMPL *session, WT_FH *fh, wt_off_t offset, size_t len, void *buf)
{
WT_DECL_RET;
+ uint64_t time_start, time_stop;
__wt_verbose(session, WT_VERB_HANDLEOPS,
"%s: handle-read: %" WT_SIZET_FMT " at %" PRIuMAX,
@@ -101,10 +109,14 @@ __wt_read(
WT_STAT_CONN_INCR_ATOMIC(session, thread_read_active);
WT_STAT_CONN_INCR(session, read_io);
+ time_start = __wt_rdtsc(session);
ret = fh->handle->fh_read(
fh->handle, (WT_SESSION *)session, offset, len, buf);
+ time_stop = __wt_rdtsc(session);
+ __wt_stat_msecs_hist_incr_fsread(session,
+ WT_TSCDIFF_MS(time_stop, time_start));
WT_STAT_CONN_DECR_ATOMIC(session, thread_read_active);
return (ret);
}
@@ -157,6 +169,7 @@ __wt_write(WT_SESSION_IMPL *session,
WT_FH *fh, wt_off_t offset, size_t len, const void *buf)
{
WT_DECL_RET;
+ uint64_t time_start, time_stop;
WT_ASSERT(session, !F_ISSET(S2C(session), WT_CONN_READONLY) ||
WT_STRING_MATCH(fh->name,
@@ -175,10 +188,14 @@ __wt_write(WT_SESSION_IMPL *session,
WT_STAT_CONN_INCR(session, write_io);
WT_STAT_CONN_INCR_ATOMIC(session, thread_write_active);
+ time_start = __wt_rdtsc(session);
ret = fh->handle->fh_write(
fh->handle, (WT_SESSION *)session, offset, len, buf);
+ time_stop = __wt_rdtsc(session);
+ __wt_stat_msecs_hist_incr_fswrite(session,
+ WT_TSCDIFF_MS(time_stop, time_start));
WT_STAT_CONN_DECR_ATOMIC(session, thread_write_active);
return (ret);
}