foolscap实现rpc(一)
来源:互联网 发布:淘宝开店找货源怎么找 编辑:程序博客网 时间:2024/05/10 23:26
任何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代表地址;
0 0
- foolscap实现rpc(一)
- foolscap实现rpc(二)
- foolscap实现rpc(三)
- RPC入门(一):RPC java代码简单实现
- hadoop RPC(一)
- RPC(一)
- 基于Netty的RPC简单框架实现(一):RPC客户端
- 一个简单的rpc框架实现(一)
- 使用Akka实现一个简单的RPC框架(一)
- 从RPC开始(一)
- RPC服务框架(一)
- RPC入门总结(一)RPC定义和原理
- 【远程调用框架】如何实现一个简单的RPC框架(一)想法与设计
- 如何写一个RPC框架(一):关注点与我的实现
- RPC服务框架(二) 简单RPC实现
- XML-RPC学习笔记(一)
- XML-RPC规范(中文)(一)
- Hadoop NameNode之RPC Server(一)
- Android Monkey Test
- pthread_create 传递参数时指针跑飞问题
- PHP学习笔记2
- linux设置nfs共享目录
- ubuntu系统常用软件安装
- foolscap实现rpc(一)
- grid的行拖曳
- vim配置
- C#基础知识
- djgpp 中断写法
- IT人为什么难以拿到高薪
- C# Web Service 根据WSDL文件和地址添加web引用
- FD_框架和类库的区别
- BOS添加字段后关于保存不上值或者保存后显出不出数