python - 当 Pyro4 客户端意外断开连接时释放资源

标签 python pyro4

我有一个 Pyro4 分布式系统,多个客户端连接到一个服务器。这些客户端连接到一个远程对象,该对象可能会在系统中分配一些资源(在我的例子中是虚拟设备)。

一旦客户端断开连接(假设是因为崩溃),我需要释放那些资源。检测特定客户端已与特定对象断开连接的正确方法是什么?

我尝试过不同的东西:

  • 重写 Daemon.clientDisconnected 方法。我从这个方法中得到一个 connection 参数。但我无法将其与对象相关联,因为我无权访问该连接所指的远程对象。
  • Daemon.clientDisconnected 中使用 Pyro4.current_context。这不起作用,因为那是一个线程本地对象。这样一来,如果我连接的客户端多于池中的线程,我会得到重复的上下文。
  • 使用 Proxy._pyroAnnotations 作为 Pyro4 项目可用的“usersession”示例,对我没有帮助,因为我再次从 Pyro4.core.current_context 获得注释.annotations 属性,它在调用 Daemon.clientDisconnected 时向我显示错误的注释(我想是由于与线程相关的问题)。
  • 在远程类中使用 instance_mode="session"__del__ 方法(因为每个客户端都有一个单独的类实例,所以该实例应该一旦客户端断开连接就会被销毁)。但这依赖于 __del__ 方法,一些 Python 程序员会指出该方法存在一些问题。

我添加了我当前的解决方案作为答案,但我真的很想知道是否有使用 Pyro4 的更优雅的方法,因为这种情况是网络编程中的循环模式。

最佳答案

Pyro 4.63 可能会为此提供一些内置支持,使其更容易实现。您可以在这里阅读 http://pyro4.readthedocs.io/en/latest/tipstricks.html#automatically-freeing-resources-when-client-connection-gets-closed如果您从 Github 克隆当前的母版,请尝试一下。或许您可以看看这是否会使您的用例更简单?

关于python - 当 Pyro4 客户端意外断开连接时释放资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45882693/

相关文章:

python - Sklearn 朴素贝叶斯与 float 一起使用时出现未知标签类型错误

python - pyvirtualdisplay 中的 XStartError

python - NDB .order 返回空结果

python - 用逗号将python一维数组分割成二维数组

python - Pyro4:在不尝试返回子对象的情况下调用远程子对象的方法

python - 如何在 Pyro v.4.63 中正确使用第三方库

python - 通过 Pyro 暴露一堆函数

python - 找不到满足 pyyaml>=5.3 要求的版本,但 PyYAML 是版本 5.3.1