我有一个应用程序将对象引用绑定到多个命名服务。如果重新启动任何这些命名服务,我希望能够检测到并重新绑定我对它的引用。现在,我能想到的唯一方法是定期轮询命名服务上下文对象,如下所示(使用omniorbpy):
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专家都有什么想法吗?
注意:网络架构和命名服务实现不受我的控制。因此,遗憾的是,切换到持久性命名服务不是一种选择。
答案 0 :(得分:1)
如果您不能使用持久性命名服务,那么我认为您唯一的选择是进行投票。但我可能只是尝试重新引用引用而不是检查它或调用_non_existant()
。