📄 rps_monitor.cpp
字号:
#include "RPS_Monitor.h"
#include "ServerRequestInterceptor.h"
#include "ace/UUID.h"
#include "tao/ORB_Constants.h"
ACE_RCSID (LoadBalancing,
RPS_Monitor,
"RPS_Monitor.cpp,v 1.3 2003/12/10 22:40:27 ossama Exp")
RPS_Monitor::RPS_Monitor (ServerRequestInterceptor * interceptor)
: location_ (1),
interceptor_ (interceptor),
last_time_ (ACE_OS::gettimeofday ()),
lock_ ()
{
this->location_.length (1);
ACE_Utils::UUID_GENERATOR::instance ()->init ();
ACE_Utils::UUID uuid;
ACE_Utils::UUID_GENERATOR::instance ()->generateUUID (uuid);
this->location_[0].id = CORBA::string_dup (uuid.to_string ()->c_str ());
this->location_[0].kind = CORBA::string_dup ("UUID");
}
RPS_Monitor::~RPS_Monitor (void)
{
}
CosLoadBalancing::Location *
RPS_Monitor::the_location (ACE_ENV_SINGLE_ARG_DECL)
ACE_THROW_SPEC ((CORBA::SystemException))
{
CosLoadBalancing::Location * location;
ACE_NEW_THROW_EX (location,
CosLoadBalancing::Location (this->location_),
CORBA::NO_MEMORY (
CORBA::SystemException::_tao_minor_code (
TAO_DEFAULT_MINOR_CODE,
ENOMEM),
CORBA::COMPLETED_NO));
ACE_CHECK_RETURN (0);
return location;
}
CosLoadBalancing::LoadList *
RPS_Monitor::loads (ACE_ENV_SINGLE_ARG_DECL)
ACE_THROW_SPEC ((CORBA::SystemException))
{
const ACE_Time_Value current_time = ACE_OS::gettimeofday ();
ACE_Time_Value elapsed_time;
{
ACE_GUARD_RETURN (ACE_SYNCH_MUTEX, monitor, this->lock_, 0);
elapsed_time = current_time - this->last_time_;
this->last_time_ = current_time;
}
const CORBA::Float request_count = this->interceptor_->request_count ();
CosLoadBalancing::LoadList * tmp;
ACE_NEW_THROW_EX (tmp,
CosLoadBalancing::LoadList (1),
CORBA::NO_MEMORY (
CORBA::SystemException::_tao_minor_code (
TAO_DEFAULT_MINOR_CODE,
ENOMEM),
CORBA::COMPLETED_NO));
ACE_CHECK_RETURN (0);
CosLoadBalancing::LoadList_var load_list = tmp;
load_list->length (1);
load_list[0].id = CosLoadBalancing::RequestsPerSecond;
if (elapsed_time == ACE_Time_Value::zero)
load_list[0].value = 0;
else
load_list[0].value = request_count / elapsed_time.msec () * 1000;
// Strictly for debugging or
ACE_DEBUG ((LM_DEBUG, "%f\n", load_list[0].value));
return load_list._retn ();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -