foolscap实现rpc(一)

任何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代表地址;

你可能感兴趣的:(foolscap实现rpc(一))