From 3ad4b1b837729ba68127fe31f4db847ecf75519b Mon Sep 17 00:00:00 2001 From: Marcel Klehr Date: Sun, 27 Oct 2013 21:43:32 +0100 Subject: [PATCH] stats: Add http500, memoryUsage, pendingEdits gauges and turn edits metric into a timer instead of a simple meter --- src/node/handler/PadMessageHandler.js | 9 +++++++-- src/node/hooks/express/errorhandling.js | 2 ++ src/node/server.js | 5 +++++ 3 files changed, 14 insertions(+), 2 deletions(-) diff --git a/src/node/handler/PadMessageHandler.js b/src/node/handler/PadMessageHandler.js index d1f1cc058..923022657 100644 --- a/src/node/handler/PadMessageHandler.js +++ b/src/node/handler/PadMessageHandler.js @@ -194,6 +194,7 @@ exports.handleMessage = function(client, message) if (sessioninfos[client.id].readonly) { messageLogger.warn("Dropped message, COLLABROOM for readonly pad"); } else if (message.data.type == "USER_CHANGES") { + stats.counter('pendingEdits').inc() padChannels.emit(message.padId, {client: client, message: message});// add to pad queue } else if (message.data.type == "USERINFO_UPDATE") { handleUserInfoUpdate(client, message); @@ -563,6 +564,9 @@ function handleUserChanges(data, cb) var client = data.client , message = data.message + // This one's no longer pending, as we're gonna process it now + stats.counter('pendingEdits').dec() + // Make sure all required fields are present if(message.data.baseRev == null) { @@ -590,8 +594,8 @@ function handleUserChanges(data, cb) var r, apool, pad; - // Log edit - stats.meter('edits').mark(); + // Measure time to process edit + var stopWatch = stats.timer('edits').start(); async.series([ //get the pad @@ -723,6 +727,7 @@ function handleUserChanges(data, cb) } ], function(err) { + stopWatch.end() cb(); if(err) console.warn(err.stack || err) }); diff --git a/src/node/hooks/express/errorhandling.js b/src/node/hooks/express/errorhandling.js index 825c5f3b4..087dd50eb 100644 --- a/src/node/hooks/express/errorhandling.js +++ b/src/node/hooks/express/errorhandling.js @@ -1,5 +1,6 @@ var os = require("os"); var db = require('../../db/DB'); +var stats = require('ep_etherpad-lite/node/stats') exports.onShutdown = false; @@ -40,6 +41,7 @@ exports.expressCreateServer = function (hook_name, args, cb) { // allowing you to respond however you like res.send(500, { error: 'Sorry, something bad happened!' }); console.error(err.stack? err.stack : err.toString()); + stats.meter('http500').mark() }) //connect graceful shutdown with sigint and uncaughtexception diff --git a/src/node/server.js b/src/node/server.js index c098b456b..605ce8479 100755 --- a/src/node/server.js +++ b/src/node/server.js @@ -23,10 +23,15 @@ var log4js = require('log4js') , async = require('async') + , stats = require('./stats') ; log4js.replaceConsole(); +stats.gauge('memoryUsage', function() { + return process.memoryUsage().rss +}) + var settings , db , plugins