Consumer event channel control. More...
#include <ECG_Reconnect_ConsumerEC_Control.h>
Public Member Functions | |
TAO_ECG_Reconnect_ConsumerEC_Control (const ACE_Time_Value &rate, const ACE_Time_Value &timeout, TAO_EC_Gateway_IIOP *gateway, CORBA::ORB_ptr orb) | |
virtual | ~TAO_ECG_Reconnect_ConsumerEC_Control (void) |
Destructor. | |
void | handle_timeout (const ACE_Time_Value &tv, const void *arg) |
Receive the timeout from the adapter. | |
virtual int | activate (void) |
virtual int | shutdown (void) |
virtual void | event_channel_not_exist (TAO_EC_Gateway_IIOP *gateway) |
virtual void | system_exception (TAO_EC_Gateway_IIOP *gateway, CORBA::SystemException &) |
Private Member Functions | |
void | query_eventchannel (void) |
void | try_reconnect (void) |
Look if we can reconnect again. | |
void | reconnect (void) |
Reconnect to the consumer ec. | |
Private Attributes | |
ACE_Time_Value | rate_ |
The polling rate. | |
ACE_Time_Value | timeout_ |
The polling timeout. | |
TAO_ECG_Reconnect_ConsumerEC_Control_Adapter | adapter_ |
The Adapter for the reactor events. | |
TAO_EC_Gateway_IIOP * | gateway_ |
The gateway. | |
CORBA::ORB_var | orb_ |
The ORB. | |
CORBA::PolicyCurrent_var | policy_current_ |
To control the timeout policy in the thread. | |
CORBA::PolicyList | policy_list_ |
Precomputed policy list to the set timeout. | |
ACE_Reactor * | reactor_ |
The ORB reactor. | |
int | is_consumer_ec_connected_ |
Do we have a connection to the consumer ec. |
Consumer event channel control.
Defines the interface for the consumer event channel control strategy. This strategy handles misbehaving or failing consumer event channels.
This control tries to reconnect to the consumer ec incase of a connection loss and then does a reconnect when the connection is back again. When also a restart of the consumer ec must be handled correctly, then the consumer ec must use a persistent IOR.
TAO_ECG_Reconnect_ConsumerEC_Control::TAO_ECG_Reconnect_ConsumerEC_Control | ( | const ACE_Time_Value & | rate, | |
const ACE_Time_Value & | timeout, | |||
TAO_EC_Gateway_IIOP * | gateway, | |||
CORBA::ORB_ptr | orb | |||
) |
Constructor. It does not assume ownership of the event_channel parameter.
TAO_ECG_Reconnect_ConsumerEC_Control::~TAO_ECG_Reconnect_ConsumerEC_Control | ( | void | ) | [virtual] |
Destructor.
int TAO_ECG_Reconnect_ConsumerEC_Control::activate | ( | void | ) | [virtual] |
Activate any internal threads or timers used to poll the state of the event channel.
Reimplemented from TAO_ECG_ConsumerEC_Control.
void TAO_ECG_Reconnect_ConsumerEC_Control::event_channel_not_exist | ( | TAO_EC_Gateway_IIOP * | gateway | ) | [virtual] |
When pushing an event to the event channel a CORBA::OBJECT_NOT_EXIST exception was raised. The only interpretation is that the object has been destroyed. The strategy has to (at the very least), reclaim all the resources attached to that object.
Reimplemented from TAO_ECG_ConsumerEC_Control.
void TAO_ECG_Reconnect_ConsumerEC_Control::handle_timeout | ( | const ACE_Time_Value & | tv, | |
const void * | arg | |||
) |
Receive the timeout from the adapter.
void TAO_ECG_Reconnect_ConsumerEC_Control::query_eventchannel | ( | void | ) | [private] |
Check if the consumers still exists. It is a helper method for handle_timeout() to isolate the exceptions.
void TAO_ECG_Reconnect_ConsumerEC_Control::reconnect | ( | void | ) | [private] |
Reconnect to the consumer ec.
int TAO_ECG_Reconnect_ConsumerEC_Control::shutdown | ( | void | ) | [virtual] |
Shutdown any internal threads or timers used to poll the state of the event channel.
Reimplemented from TAO_ECG_ConsumerEC_Control.
void TAO_ECG_Reconnect_ConsumerEC_Control::system_exception | ( | TAO_EC_Gateway_IIOP * | gateway, | |
CORBA::SystemException & | ||||
) | [virtual] |
Some system exception was raised while trying to contact the event channel
Reimplemented from TAO_ECG_ConsumerEC_Control.
void TAO_ECG_Reconnect_ConsumerEC_Control::try_reconnect | ( | void | ) | [private] |
Look if we can reconnect again.
TAO_ECG_Reconnect_ConsumerEC_Control_Adapter TAO_ECG_Reconnect_ConsumerEC_Control::adapter_ [private] |
The Adapter for the reactor events.
The gateway.
Do we have a connection to the consumer ec.
The ORB.
CORBA::PolicyCurrent_var TAO_ECG_Reconnect_ConsumerEC_Control::policy_current_ [private] |
To control the timeout policy in the thread.
CORBA::PolicyList TAO_ECG_Reconnect_ConsumerEC_Control::policy_list_ [private] |
Precomputed policy list to the set timeout.
The polling rate.
The ORB reactor.
The polling timeout.