Add flush_total_time_ns and additional wired tiger fields to mongodb input (#5273)

This commit is contained in:
Artem V. Navrotskiy 2019-01-15 22:31:52 +03:00 committed by Daniel Nelson
parent ccfd9ca522
commit df33759711
4 changed files with 45 additions and 6 deletions

View File

@ -61,6 +61,7 @@ Error in input [mongodb]: not authorized on admin to execute command { serverSta
- document_returned (integer) - document_returned (integer)
- document_updated (integer) - document_updated (integer)
- flushes (integer) - flushes (integer)
- flushes_total_time_ns (integer)
- getmores (integer) - getmores (integer)
- inserts (integer - inserts (integer
- jumbo_chunks (integer) - jumbo_chunks (integer)
@ -96,8 +97,13 @@ Error in input [mongodb]: not authorized on admin to execute command { serverSta
- wtcache_app_threads_page_write_count (integer) - wtcache_app_threads_page_write_count (integer)
- wtcache_bytes_read_into (integer) - wtcache_bytes_read_into (integer)
- wtcache_bytes_written_from (integer) - wtcache_bytes_written_from (integer)
- wtcache_pages_read_info (integer)
- wtcache_pages_requested_from (integer)
- wtcache_current_bytes (integer) - wtcache_current_bytes (integer)
- wtcache_max_bytes_configured (integer) - wtcache_max_bytes_configured (integer)
- wtcache_internal_pages_evicted (integer)
- wtcache_modified_pages_evicted (integer)
- wtcache_unmodified_pages_evicted (integer)
- wtcache_pages_evicted_by_app_thread (integer) - wtcache_pages_evicted_by_app_thread (integer)
- wtcache_pages_queued_for_eviction (integer) - wtcache_pages_queued_for_eviction (integer)
- wtcache_server_evicting_pages (integer) - wtcache_server_evicting_pages (integer)

View File

@ -45,6 +45,7 @@ var DefaultStats = map[string]string{
"commands_per_sec": "Command", "commands_per_sec": "Command",
"flushes": "FlushesCnt", "flushes": "FlushesCnt",
"flushes_per_sec": "Flushes", "flushes_per_sec": "Flushes",
"flushes_total_time_ns": "FlushesTotalTime",
"vsize_megabytes": "Virtual", "vsize_megabytes": "Virtual",
"resident_megabytes": "Resident", "resident_megabytes": "Resident",
"queued_reads": "QueuedReaders", "queued_reads": "QueuedReaders",
@ -137,8 +138,13 @@ var WiredTigerExtStats = map[string]string{
"wtcache_bytes_read_into": "BytesReadInto", "wtcache_bytes_read_into": "BytesReadInto",
"wtcache_pages_evicted_by_app_thread": "PagesEvictedByAppThread", "wtcache_pages_evicted_by_app_thread": "PagesEvictedByAppThread",
"wtcache_pages_queued_for_eviction": "PagesQueuedForEviction", "wtcache_pages_queued_for_eviction": "PagesQueuedForEviction",
"wtcache_pages_read_info": "PagesReadIntoCache",
"wtcache_pages_requested_from": "PagesRequestedFromCache",
"wtcache_server_evicting_pages": "ServerEvictingPages", "wtcache_server_evicting_pages": "ServerEvictingPages",
"wtcache_worker_thread_evictingpages": "WorkerThreadEvictingPages", "wtcache_worker_thread_evictingpages": "WorkerThreadEvictingPages",
"wtcache_internal_pages_evicted": "InternalPagesEvicted",
"wtcache_modified_pages_evicted": "ModifiedPagesEvicted",
"wtcache_unmodified_pages_evicted": "UnmodifiedPagesEvicted",
} }
var DbDataStats = map[string]string{ var DbDataStats = map[string]string{

View File

@ -56,7 +56,7 @@ func TestAddNonReplStats(t *testing.T) {
d.flush(&acc) d.flush(&acc)
for key := range DefaultStats { for key := range DefaultStats {
assert.True(t, acc.HasInt64Field("mongodb", key)) assert.True(t, acc.HasFloatField("mongodb", key) || acc.HasInt64Field("mongodb", key), key)
} }
} }
@ -77,7 +77,7 @@ func TestAddReplStats(t *testing.T) {
d.flush(&acc) d.flush(&acc)
for key := range MmapStats { for key := range MmapStats {
assert.True(t, acc.HasInt64Field("mongodb", key)) assert.True(t, acc.HasInt64Field("mongodb", key), key)
} }
} }
@ -109,7 +109,11 @@ func TestAddWiredTigerStats(t *testing.T) {
d.flush(&acc) d.flush(&acc)
for key := range WiredTigerStats { for key := range WiredTigerStats {
assert.True(t, acc.HasFloatField("mongodb", key)) assert.True(t, acc.HasFloatField("mongodb", key), key)
}
for key := range WiredTigerExtStats {
assert.True(t, acc.HasFloatField("mongodb", key) || acc.HasInt64Field("mongodb", key), key)
} }
} }
@ -199,6 +203,7 @@ func TestStateTag(t *testing.T) {
"deletes_per_sec": int64(0), "deletes_per_sec": int64(0),
"flushes": int64(0), "flushes": int64(0),
"flushes_per_sec": int64(0), "flushes_per_sec": int64(0),
"flushes_total_time_ns": int64(0),
"getmores": int64(0), "getmores": int64(0),
"getmores_per_sec": int64(0), "getmores_per_sec": int64(0),
"inserts": int64(0), "inserts": int64(0),

View File

@ -168,13 +168,19 @@ type CacheStats struct {
BytesReadInto int64 `bson:"bytes read into cache"` BytesReadInto int64 `bson:"bytes read into cache"`
PagesEvictedByAppThread int64 `bson:"pages evicted by application threads"` PagesEvictedByAppThread int64 `bson:"pages evicted by application threads"`
PagesQueuedForEviction int64 `bson:"pages queued for eviction"` PagesQueuedForEviction int64 `bson:"pages queued for eviction"`
PagesReadIntoCache int64 `bson:"pages read into cache"`
PagesRequestedFromCache int64 `bson:"pages requested from the cache"`
ServerEvictingPages int64 `bson:"eviction server evicting pages"` ServerEvictingPages int64 `bson:"eviction server evicting pages"`
WorkerThreadEvictingPages int64 `bson:"eviction worker thread evicting pages"` WorkerThreadEvictingPages int64 `bson:"eviction worker thread evicting pages"`
InternalPagesEvicted int64 `bson:"internal pages evicted"`
ModifiedPagesEvicted int64 `bson:"modified pages evicted"`
UnmodifiedPagesEvicted int64 `bson:"unmodified pages evicted"`
} }
// TransactionStats stores transaction checkpoints in WiredTiger. // TransactionStats stores transaction checkpoints in WiredTiger.
type TransactionStats struct { type TransactionStats struct {
TransCheckpoints int64 `bson:"transaction checkpoints"` TransCheckpointsTotalTimeMsecs int64 `bson:"transaction checkpoint total time (msecs)"`
TransCheckpoints int64 `bson:"transaction checkpoints"`
} }
// ReplStatus stores data related to replica sets. // ReplStatus stores data related to replica sets.
@ -498,8 +504,13 @@ type StatLine struct {
BytesReadInto int64 BytesReadInto int64
PagesEvictedByAppThread int64 PagesEvictedByAppThread int64
PagesQueuedForEviction int64 PagesQueuedForEviction int64
PagesReadIntoCache int64
PagesRequestedFromCache int64
ServerEvictingPages int64 ServerEvictingPages int64
WorkerThreadEvictingPages int64 WorkerThreadEvictingPages int64
InternalPagesEvicted int64
ModifiedPagesEvicted int64
UnmodifiedPagesEvicted int64
// Replicated Opcounter fields // Replicated Opcounter fields
InsertR, InsertRCnt int64 InsertR, InsertRCnt int64
@ -511,6 +522,7 @@ type StatLine struct {
ReplLag int64 ReplLag int64
OplogTimeDiff int64 OplogTimeDiff int64
Flushes, FlushesCnt int64 Flushes, FlushesCnt int64
FlushesTotalTime int64
Mapped, Virtual, Resident, NonMapped int64 Mapped, Virtual, Resident, NonMapped int64
Faults, FaultsCnt int64 Faults, FaultsCnt int64
HighestLocked *LockStatus HighestLocked *LockStatus
@ -666,8 +678,7 @@ func NewStatLine(oldMongo, newMongo MongoStatus, key string, all bool, sampleSec
returnVal.CacheDirtyPercent = -1 returnVal.CacheDirtyPercent = -1
returnVal.CacheUsedPercent = -1 returnVal.CacheUsedPercent = -1
if newStat.WiredTiger != nil && oldStat.WiredTiger != nil { if newStat.WiredTiger != nil {
returnVal.Flushes, returnVal.FlushesCnt = diff(newStat.WiredTiger.Transaction.TransCheckpoints, oldStat.WiredTiger.Transaction.TransCheckpoints, sampleSecs)
returnVal.CacheDirtyPercent = float64(newStat.WiredTiger.Cache.TrackedDirtyBytes) / float64(newStat.WiredTiger.Cache.MaxBytesConfigured) returnVal.CacheDirtyPercent = float64(newStat.WiredTiger.Cache.TrackedDirtyBytes) / float64(newStat.WiredTiger.Cache.MaxBytesConfigured)
returnVal.CacheUsedPercent = float64(newStat.WiredTiger.Cache.CurrentCachedBytes) / float64(newStat.WiredTiger.Cache.MaxBytesConfigured) returnVal.CacheUsedPercent = float64(newStat.WiredTiger.Cache.CurrentCachedBytes) / float64(newStat.WiredTiger.Cache.MaxBytesConfigured)
@ -681,8 +692,19 @@ func NewStatLine(oldMongo, newMongo MongoStatus, key string, all bool, sampleSec
returnVal.BytesReadInto = newStat.WiredTiger.Cache.BytesReadInto returnVal.BytesReadInto = newStat.WiredTiger.Cache.BytesReadInto
returnVal.PagesEvictedByAppThread = newStat.WiredTiger.Cache.PagesEvictedByAppThread returnVal.PagesEvictedByAppThread = newStat.WiredTiger.Cache.PagesEvictedByAppThread
returnVal.PagesQueuedForEviction = newStat.WiredTiger.Cache.PagesQueuedForEviction returnVal.PagesQueuedForEviction = newStat.WiredTiger.Cache.PagesQueuedForEviction
returnVal.PagesReadIntoCache = newStat.WiredTiger.Cache.PagesReadIntoCache
returnVal.PagesRequestedFromCache = newStat.WiredTiger.Cache.PagesRequestedFromCache
returnVal.ServerEvictingPages = newStat.WiredTiger.Cache.ServerEvictingPages returnVal.ServerEvictingPages = newStat.WiredTiger.Cache.ServerEvictingPages
returnVal.WorkerThreadEvictingPages = newStat.WiredTiger.Cache.WorkerThreadEvictingPages returnVal.WorkerThreadEvictingPages = newStat.WiredTiger.Cache.WorkerThreadEvictingPages
returnVal.InternalPagesEvicted = newStat.WiredTiger.Cache.InternalPagesEvicted
returnVal.ModifiedPagesEvicted = newStat.WiredTiger.Cache.ModifiedPagesEvicted
returnVal.UnmodifiedPagesEvicted = newStat.WiredTiger.Cache.UnmodifiedPagesEvicted
returnVal.FlushesTotalTime = newStat.WiredTiger.Transaction.TransCheckpointsTotalTimeMsecs * int64(time.Millisecond)
}
if newStat.WiredTiger != nil && oldStat.WiredTiger != nil {
returnVal.Flushes, returnVal.FlushesCnt = diff(newStat.WiredTiger.Transaction.TransCheckpoints, oldStat.WiredTiger.Transaction.TransCheckpoints, sampleSecs)
} else if newStat.BackgroundFlushing != nil && oldStat.BackgroundFlushing != nil { } else if newStat.BackgroundFlushing != nil && oldStat.BackgroundFlushing != nil {
returnVal.Flushes, returnVal.FlushesCnt = diff(newStat.BackgroundFlushing.Flushes, oldStat.BackgroundFlushing.Flushes, sampleSecs) returnVal.Flushes, returnVal.FlushesCnt = diff(newStat.BackgroundFlushing.Flushes, oldStat.BackgroundFlushing.Flushes, sampleSecs)
} }