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代表地址;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值