diff options
author | Ben Becker <ben.becker@10gen.com> | 2013-03-29 15:44:08 -0700 |
---|---|---|
committer | Ben Becker <ben.becker@10gen.com> | 2013-03-29 16:06:30 -0700 |
commit | e4890bf85c97c5b4d8d1797a77ad0e3cb5bf95f3 (patch) | |
tree | ede48501698802ff6935477819dd4670bb67ab04 | |
parent | 337b300277bbd104bb0012eecc09cc22bf091d8b (diff) | |
download | mongo-e4890bf85c97c5b4d8d1797a77ad0e3cb5bf95f3.tar.gz |
SERVER-9185: add v8 GC epligoue stats
-rw-r--r-- | src/mongo/scripting/engine_v8.cpp | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/src/mongo/scripting/engine_v8.cpp b/src/mongo/scripting/engine_v8.cpp index a70f05b7f99..244e4bbc8eb 100644 --- a/src/mongo/scripting/engine_v8.cpp +++ b/src/mongo/scripting/engine_v8.cpp @@ -296,6 +296,15 @@ namespace mongo { return v8::Boolean::New(false); } + /** + * GC Prologue and Epilogue constants (used to display description constants) + */ + struct GCPrologueState { static const char* name; }; + const char* GCPrologueState::name = "prologue"; + struct GCEpilogueState { static const char* name; }; + const char* GCEpilogueState::name = "epilogue"; + + template <typename _GCState> void gcCallback(v8::GCType type, v8::GCCallbackFlags flags) { const int verbosity = 1; // log level for stat collection if (logLevel < verbosity) @@ -304,12 +313,13 @@ namespace mongo { v8::HeapStatistics stats; v8::V8::GetHeapStatistics(&stats); - LOG(verbosity) << "V8 GC heap stats - " - << " total: " << stats.total_heap_size() - << " exec: " << stats.total_heap_size_executable() - << " used: " << stats.used_heap_size()<< " limit: " - << stats.heap_size_limit() - << endl; + log() << "V8 GC " << _GCState::name + << " heap stats - " + << " total: " << stats.total_heap_size() + << " exec: " << stats.total_heap_size_executable() + << " used: " << stats.used_heap_size()<< " limit: " + << stats.heap_size_limit() + << endl; } V8ScriptEngine::V8ScriptEngine() : @@ -466,7 +476,8 @@ namespace mongo { v8::Context::Scope context_scope(_context); // display heap statistics on MarkAndSweep GC run - v8::V8::AddGCPrologueCallback(gcCallback, v8::kGCTypeMarkSweepCompact); + v8::V8::AddGCPrologueCallback(gcCallback<GCPrologueState>, v8::kGCTypeMarkSweepCompact); + v8::V8::AddGCEpilogueCallback(gcCallback<GCEpilogueState>, v8::kGCTypeMarkSweepCompact); // if the isolate runs out of heap space, raise a flag on the StackGuard instead of // calling abort() |