📄 replication_service.cpp
字号:
// Replication_Service.cpp,v 1.7 2003/12/01 18:26:59 huangming Exp
#include "Replication_Service.h"
#include "AMI_Replication_Strategy.h"
#include "Basic_Replication_Strategy.h"
#include "FTEC_ORBInitializer.h"
#include "tao/ORBInitializer_Registry.h"
#include "ace/OS_NS_strings.h"
ACE_RCSID (EventChannel,
Replication_Service,
"Replication_Service.cpp,v 1.7 2003/12/01 18:26:59 huangming Exp")
namespace FTRTEC
{
namespace {
auto_ptr<Replication_Strategy> replication_strategy;
Replication_Service* service;
}
Replication_Service* Replication_Service::instance()
{
return service;
}
Replication_Service::Replication_Service()
{
service = this;
}
Replication_Service::~Replication_Service()
{
}
int Replication_Service::init (int argc, ACE_TCHAR* argv[])
{
static int initialized = 0;
// Only allow initialization once.
if (initialized)
return 0;
initialized = 1;
Replication_Strategy* strategy;
// Parse any service configurator parameters.
if (argc > 0 && ACE_OS::strcasecmp (argv[0], ACE_LIB_TEXT("AMI")) == 0)
ACE_NEW_RETURN (strategy, AMI_Replication_Strategy, -1);
else
ACE_NEW_RETURN (strategy, Basic_Replication_Strategy, -1);
ACE_AUTO_PTR_RESET (replication_strategy, strategy, Replication_Strategy);
ACE_TRY_NEW_ENV
{
PortableInterceptor::ORBInitializer_ptr temp_orb_initializer =
PortableInterceptor::ORBInitializer::_nil ();
PortableInterceptor::ORBInitializer_var orb_initializer;
/// Register the RTCORBA ORBInitializer.
ACE_NEW_THROW_EX (temp_orb_initializer,
FTEC_ORBInitializer,
CORBA::NO_MEMORY ());
ACE_TRY_CHECK;
orb_initializer = temp_orb_initializer;
PortableInterceptor::register_orb_initializer (orb_initializer.in ()
ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
}
ACE_CATCHANY
{
ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
"Unexpected exception caught while "
"initializing the TransactionDepth");
return -1;
}
ACE_ENDTRY;
return 0;
}
void Replication_Service::become_primary()
{
Replication_Strategy* strategy =
replication_strategy->make_primary_strategy();
ACE_ASSERT(strategy);
if (replication_strategy.get() != strategy) {
ACE_AUTO_PTR_RESET(replication_strategy, strategy, Replication_Strategy);
}
}
void Replication_Service::check_validity(ACE_ENV_SINGLE_ARG_DECL)
{
replication_strategy->check_validity(ACE_ENV_SINGLE_ARG_PARAMETER);
}
void Replication_Service::replicate_request(const FtRtecEventChannelAdmin::Operation& update,
RollbackOperation rollback
ACE_ENV_ARG_DECL)
{
TAO_OutputCDR cdr;
cdr << update;
ACE_Message_Block mb;
ACE_CDR::consolidate(&mb, cdr.begin());
FTRT::State state(mb.length(), &mb);
//FT::State state;
replication_strategy->replicate_request(
state,
rollback,
update.object_id
ACE_ENV_ARG_PARAMETER);
}
int Replication_Service::acquire_read (void)
{
int r = replication_strategy->acquire_read();
ACE_DEBUG((LM_DEBUG, "Read Lock acquired %d\n", r));
return r;
}
int Replication_Service::acquire_write (void)
{
int r= replication_strategy->acquire_write();
ACE_DEBUG((LM_DEBUG, "Write Lock acqured %d\n", r));
return r;
}
int Replication_Service::release (void)
{
int r= replication_strategy->release();
ACE_DEBUG((LM_DEBUG, "Lock Released %d\n", r));
return r;
}
ACE_FACTORY_DEFINE (TAO_FTRTEC, Replication_Service)
ACE_STATIC_SVC_DEFINE (Replication_Service,
ACE_TEXT ("FTRTEC_Replication"),
ACE_SVC_OBJ_T,
&ACE_SVC_NAME (Replication_Service),
ACE_Service_Type::DELETE_THIS
| ACE_Service_Type::DELETE_OBJ,
0)
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -