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代表地址;
让一个对象包含有远程可调用函数的最常用的方式的是继承类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(三)
- foolscap实现rpc(二)
- foolscap实现rpc(四)
- foolscap实现rpc(一)
- foolscap实现rpc(三)
- foolscap实现rpc(二)
- Android的xml-Rpc实现
- 【Java】java实现的远程调用例子 rpc原理
- log4j2实现自定义Appender(输出到文件/RPC服务中)
- RPC原理和实现
- hadoop RPC框架实现和NameNode的交互
- 自己用 Netty 实现一个简单的 RPC
- 简单RPC之Socket实现
- (3)、exchange的几种类型及RPC的实现
- xml-rpc-c学习有感—c语言不定参函数的实现
- Dubbo源代码实现五:RPC中的服务消费方实现
- Dubbo源代码实现五:RPC中的服务消费方实现
- Hadoop2.4.1 RPC实现的底层原理(一)
- Hprose轻松实现远程过程调用(RPC)
- 利用zookeeper实现简单的RPC框架