即使在loopCondition为False之后,requestloop(loopCondition)也不会释放

时间:2011-12-14 16:35:52

标签: python pyro

我对Pyro4.Daemon对象的requestLoop方法有一些问题。

我想要的是远程调用“stop()”方法来释放requestLoop函数并关闭我的守护进程。

这个小例子不起作用

SERVER

#!/usr/bin/python
# -*- coding: utf-8 -*-
from daemon import Pyro4

class Audit(object):
    def start_audit(self):
        with Pyro4.Daemon() as daemon:
            self_uri = daemon.register(self)
            ns = Pyro4.locateNS()
            ns.register("Audit", self_uri)
            self.running = True
            print("starting")
            daemon.requestLoop(loopCondition=self.still_running)
            print("stopped")
            self.running = None

    def hi(self, string):
        print string

    def stop(self):
        self.running = False

    def still_running(self):
        return self.running

def main():

    # lancement de l'auditor
    auditor = Audit()
    auditor.start_audit()

if __name__ == "__main__" :
    main()

客户端

import Pyro4

def main():

    with  Pyro4.Proxy("PYRONAME:Audit") as au:
        au.hi("hello")
        au.hi("another hi")
        au.stop()

我期望看到服务器打印“hello”和“another hi”然后关闭。

但是没有发生关闭,服务器仍然在requestloop方法中被阻止。 只要我愿意,我就可以使用我的代理。

但是,如果我创建另一个客户端,在第一次远程调用时,服务器将关闭,客户端将抛出错误:

Pyro4.errors.ConnectionClosedError: receiving: not enough data

我所有的测试都说我需要创建第二个代理并抛出exeption以便在我的服务器上传递requestloop。

有没有人知道如何清理这个问题?

1 个答案:

答案 0 :(得分:2)

如果查看来源中的examples/callback/client.py,您会看到以下评论:

# We need to set either a socket communication timeout,
# or use the select based server. Otherwise the daemon requestLoop
# will block indefinitely and is never able to evaluate the loopCondition.
Pyro4.config.COMMTIMEOUT=0.5

因此,您需要在服务器文件中设置COMMTIMEOUT,根据我的测试,它将正常工作。

注意:您还可以向print方法添加still_running语句,以检查它何时被调用。如果没有上面的配置,您将看到看起来该方法仅在收到新事件时执行,因此服务器在下一个事件之后不会关闭到将running设置为{{1收到了。例如,如果您执行两次客户端程序,服务器将关闭。