我有一个将对象引用绑定到多个命名服务的应用程序。如果这些命名服务中的任何一个被重新启动,我希望能够检测到并重新绑定我对它的引用。现在,我能想到的唯一方法是定期轮询命名服务上下文对象,如下所示(使用omniorpy):
def check_connection(context):
try:
if CORBA.is_nil(context):
return False
if context._non_existent():
return False
except CORBA.Exception:
return False
else:
return True
我知道_non_existent()不是用来做"ping"操作的,但我想不出其他方法。如果有一种方法可以在连接丢失时通过回调得到通知,而不必不断轮询服务,那就太好了。有CORBA专家有什么想法吗?
注意:网络架构和命名服务的实现超出了我的控制范围。因此,不幸的是,切换到持久命名服务并不是一个选择。
如果您不能使用持久命名服务,那么我认为您唯一的选择就是轮询。但我可能只是尝试重新绑定引用,而不是检查它或调用_non_existant()
。