So senden Sie eine Funktion an ein entferntes Pyro-Objekt

Ich versuche, einen Code mit Pyro einzurichten, um Python-Codefunktionen auf einem Remote-Host zu verarbeiten und Ergebnisse zurückzugewinnen. Nach dem Start des Nameservers würde ich diesen Code auf dem Remote-Host ausführen (eigentlich immer noch auf localhost):

<code>import Pyro4

class Server(object):
    def evaluate(self, func, args):
        return func(*args)

def main():
    server = Server()
    Pyro4.Daemon.serveSimple(
            {
                server: "server"
            },
            ns=True)

if __name__ == '__main__':
    main()
</code>

Auf der Clientseite habe ich diesen Code, der ein Beispiel für das Verhalten ist, das ich einzurichten versuche.

<code>import Pyro4

remoteServer = Pyro4.Proxy('PYRONAME:server')

def square(x): 
    return x**2

print remoteServer.evaluate(square, 4)
</code>

Dieser Code führt jedoch zu der folgenden Ausnahme:

<code>/usr/lib/python2.7/site-packages/Pyro4/core.py:155: UserWarning: HMAC_KEY not set,
protocol data may not be secure
warnings.warn("HMAC_KEY not set, protocol data may not be secure")
Traceback (most recent call last):
  File "/home/davide/Projects/rempy/example-api-pyro.py", line 7, in <module>
    print remoteServer.evaluate(square, 4)
  File "/usr/lib/python2.7/site-packages/Pyro4/core.py", line 149, in __call__
    return self.__send(self.__name, args, kwargs)
  File "/usr/lib/python2.7/site-packages/Pyro4/core.py", line 289, in _pyroInvoke
    raise data
AttributeError: 'module' object has no attribute 'square'
</code>

Mir scheint, dass das Funktionsobjekt korrekt ausgewählt und an die Serverinstanz auf dem Remote-Host gesendet wurde, aber es liegt ein Problem im Namespace vor.

Wie kann ich dieses Problem lösen?

Vielen Dank

Antworten auf die Frage(1)

Ihre Antwort auf die Frage