diff options
author | Daniel Ernst <daniel.ernst@mongodb.com> | 2019-12-20 21:45:35 +0000 |
---|---|---|
committer | evergreen <evergreen@mongodb.com> | 2019-12-20 21:45:35 +0000 |
commit | 0e8ae6324e515b947b59d23988f2e7238a2f30c6 (patch) | |
tree | b15914c4e709fbe68640bbd9abedcefcd7a73477 /jstests/replsets/oplog_slow_sampling_logging.js | |
parent | c639699a24f389532b61f4f23323ef449c6813a5 (diff) | |
download | mongo-0e8ae6324e515b947b59d23988f2e7238a2f30c6.tar.gz |
SERVER-41790 Log progress during oplog sampling at startup
Diffstat (limited to 'jstests/replsets/oplog_slow_sampling_logging.js')
-rw-r--r-- | jstests/replsets/oplog_slow_sampling_logging.js | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/jstests/replsets/oplog_slow_sampling_logging.js b/jstests/replsets/oplog_slow_sampling_logging.js new file mode 100644 index 00000000000..70154d698af --- /dev/null +++ b/jstests/replsets/oplog_slow_sampling_logging.js @@ -0,0 +1,57 @@ +/** + * Ensure serverStatus reports the total time spent sampling the oplog for all storage engines that + * support OplogStones. + * @tags: [ requires_wiredtiger, requires_persistence, requires_fcv_44 ] + */ +(function() { +"use strict"; + +const kOplogDocs = 45000; +// kNumOplogSamples is derived from the number of oplog entries above. +const kNumOplogSamples = 15; +const kOplogSampleReadDelay = 1; +const kLoggingIntervalSeconds = 3; + +const testDB = "test"; + +// Force oplog sampling to occur on start up for small numbers of oplog inserts. +const replSet = new ReplSetTest({ + nodes: 1, + nodeOptions: { + setParameter: { + "maxOplogTruncationPointsDuringStartup": 10, + "oplogSamplingLogIntervalSeconds": kLoggingIntervalSeconds, + "failpoint.slowOplogSamplingReads": + tojson({mode: "alwaysOn", data: {"delay": kOplogSampleReadDelay}}) + } + } +}); +replSet.startSet(); +replSet.initiate(); + +let coll = replSet.getPrimary().getDB(testDB).getCollection("testcoll"); + +// Insert enough documents to force kNumOplogSamples to be taken on the following start up. +for (let i = 0; i < kOplogDocs; i++) { + assert.commandWorked(coll.insert({m: 1 + i})); +} + +// Restart replica set to load entries from the oplog for sampling. +replSet.stopSet(null /* signal */, true /* forRestart */); +replSet.startSet({restart: true}); + +assert.commandWorked(replSet.getPrimary().getDB(testDB).serverStatus()); + +// Err on the side of a smaller minExpectedLogs where fractional parts are concerned because +// kLoggingIntervalSeconds is not an exact interval. Rather, once interval seconds have elapsed +// since the last log message, a progress message will be logged after the current sample is +// completed. +const maxSamplesPerLog = Math.ceil(kLoggingIntervalSeconds / kOplogSampleReadDelay); +const minExpectedLogs = Math.floor(kNumOplogSamples / maxSamplesPerLog); + +checkLog.containsWithAtLeastCount( + replSet.getPrimary(), "Oplog sampling progress:", minExpectedLogs); +assert(checkLog.checkContainsOnce(replSet.getPrimary(), "Oplog sampling complete")); + +replSet.stopSet(); +})(); |