您的位置:首页 > 其它

foolscap实现rpc(一)

2013-12-27 09:50 253 查看
任何Foolscap应用都至少有2端:一个有远端可调用的对象,另一个是调用这个对象的多个方法;下面我们将会以一个简单的例子演示。之后,我们会增加一些特征,比如说:RemoteInterface声明和转移对象引用等;

让一个对象包含有远程可调用函数的最常用的方式的是继承类Referenceable。首先,我们创建简单的执行算术操作的server。你可以使用这些服务来完成更大的数值计算,比如,加法,在远程机器上比在你自己的机器上更快和可用;

from foolscap.api import Referenceable

class MathServer(Referenceable):

#此时的MathServer对象就包含了能远程访问的函数方法

def remote_add(self, a, b):

return a+b

def remote_subtract(self, a, b):

return a-b

def remote_sum(self, args):

total = 0

for a in args: total += a

return total

myserver = MathServer()

#以上的程序可以作为server服务器程序;

那么客户端部分的程序呢?

如下所示:

def gotanswer(result):

print “result is:” , result

def goterr(err):

print “error:”, err

d = remote.callRemote(“add”, 1, 2)

d.addCallbacks(gotanwser, goterr)

大家一定对程序中出现的remote和callRemote感到困惑,但是意思很清楚,就是用来做远程调用的类实例;

那么,如何获取整个类实例呢?它定义在RemoteReference类中。还记得我们的server端的代码吗?里面有一个Referenceable类实例,那我们如何才能让这个对象可以从远程调用呢?那么就必须在server和client之间建立某种联系,我们称之为Tub和FURL,其中Tub代表硬件,FURL代表地址;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: