X-Git-Url: https://git.teslayout.com/public/public/public/?p=anna.git;a=blobdiff_plain;f=source%2Fdiameter.comm%2FLocalServer.cpp;h=0e2bc2ebd7f0d48425cac338e987c5c80ad4c96c;hp=63741825afea3ebdddf581ee6fad61b92a4f481d;hb=028006fc5ee34967fcfffff24a2b1c8b410c26c3;hpb=3b71d6454d211ec50c2f3e04b04c607c382f2f29 diff --git a/source/diameter.comm/LocalServer.cpp b/source/diameter.comm/LocalServer.cpp index 6374182..0e2bc2e 100644 --- a/source/diameter.comm/LocalServer.cpp +++ b/source/diameter.comm/LocalServer.cpp @@ -43,8 +43,7 @@ LocalServer::LocalServer() : a_category(0), a_lock(false), a_available(false), - a_lastUsedResource(NULL), - a_statisticsAccumulator(NULL) {} + a_lastUsedResource(NULL) {} void LocalServer::initializeStatisticResources() throw() { @@ -55,26 +54,23 @@ void LocalServer::initializeStatisticResources() throw() { accName += "' and origin-host '"; accName += a_engine ? a_engine->getOriginHost() : "unknown"; // it should be known (createServer) accName += "'"; - a_statisticsAccumulator = anna::statistics::Engine::instantiate().createAccumulator(accName); - a_processing_time__StatisticConceptId = a_statisticsAccumulator->addConcept("Diameter requests processing time at clients connected to", "ms", true/* integer values */); - a_received_message_size__StatisticConceptId = a_statisticsAccumulator->addConcept("Diameter message sizes received from clients connected to", "bytes", true/* integer values */); + a_messageStatistics.initialize(accName); } void LocalServer::resetStatistics() throw() { - a_statisticsAccumulator->reset(); + a_messageStatistics.getAccumulator()->reset(); } -void LocalServer::updateProcessingTimeStatisticConcept(const double &value) throw() { - a_statisticsAccumulator->process(a_processing_time__StatisticConceptId, value); - LOGDEBUG(anna::Logger::debug(a_statisticsAccumulator->asString(), ANNA_FILE_LOCATION)); +void LocalServer::updateProcessingTimeStatisticConcept(const double &value, const anna::diameter::CommandId &cid) throw() { + a_messageStatistics.process(MessageStatistics::ConceptType::SentRequestProcessingTime, cid, value); + LOGDEBUG(anna::Logger::debug(a_messageStatistics.getAccumulator()->asString(), ANNA_FILE_LOCATION)); } -void LocalServer::updateReceivedMessageSizeStatisticConcept(const double &value) throw() { - a_statisticsAccumulator->process(a_received_message_size__StatisticConceptId, value); - //LOGDEBUG(anna::Logger::debug(a_statisticsAccumulator->asString(), ANNA_FILE_LOCATION)); +void LocalServer::updateReceivedMessageSizeStatisticConcept(const double &value, const anna::diameter::CommandId &cid) throw() { + a_messageStatistics.process(MessageStatistics::ConceptType::ReceivedMessageSize, cid, value); + LOGDEBUG(anna::Logger::debug(a_messageStatistics.getAccumulator()->asString(), ANNA_FILE_LOCATION)); } - ServerSession* LocalServer::allocateServerSession() throw() { return a_serverSessionsRecycler.create(); } void LocalServer::releaseServerSession(ServerSession *serverSession) throw() { a_serverSessionsRecycler.release(serverSession); } @@ -400,7 +396,7 @@ void LocalServer::setClassCodeTimeout(const ClassCode::_v v, const anna::Millise } void LocalServer::setMaxConnections(int maxConnections) throw(anna::RuntimeException) { - LOGMETHOD(anna::TraceMethod tttm("diameter::comm::LocalServer", "setMaxConnections", ANNA_FILE_LOCATION)); + LOGMETHOD(anna::TraceMethod tttm("anna::diameter::comm::LocalServer", "setMaxConnections", ANNA_FILE_LOCATION)); // Negative & initial if(maxConnections < 0) { @@ -576,7 +572,7 @@ std::string LocalServer::asString() const throw() { result += " | Last Outgoing Activity Time: "; result += a_lastOutgoingActivityTime.asString(); // result += "\n"; -// result += a_statisticsAccumulator->asString(); +// result += a_messageStatistics.getAccumulator()->asString(); // ServerSessions only in xml return result += " }"; } @@ -600,8 +596,8 @@ anna::xml::Node* LocalServer::asXML(anna::xml::Node* parent) const throw() { result->createAttribute("LastIncomingActivityTime", a_lastIncomingActivityTime.asString()); result->createAttribute("LastOutgoingActivityTime", a_lastOutgoingActivityTime.asString()); // Statistics - anna::xml::Node* stats = result->createChild("Statistics"); - a_statisticsAccumulator->asXML(stats); + anna::xml::Node* stats = result->createChild("MessageStatistics"); + a_messageStatistics.getAccumulator()->asXML(stats); anna::xml::Node* serverSessions = result->createChild("ServerSessions"); // LocalServer.ServerSessions for(const_serverSession_iterator it = serverSession_begin(); it != serverSession_end(); it++)