Como enviar uma função para um objeto Pyro remoto

Eu estou tentando configurar algum código usando o Pyro para processar funções de código python em um host remoto e obter resultados de volta. Depois de iniciar o servidor de nomes, eu iria executar este código no host remoto (na verdade, ainda no 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>

No lado do cliente eu tenho esse código, que é um exemplo do comportamento que estou tentando configurar.

<code>import Pyro4

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

def square(x): 
    return x**2

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

No entanto, esse código resulta na seguinte exceção:

<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>

Parece-me que o objeto de função é decapado corretamente e é enviado para a instância do servidor no host remoto, mas há algum problema no namespace.

Como posso resolver este problema?

obrigado

questionAnswers(1)

yourAnswerToTheQuestion