python远程过程调用记录


title: python远程过程调用记录
date: 2017-12-29 11:23:53
tags: [xmlrpc,jsonrpc,web2py]


需求

现有的两个web服务器之间需要打通传递数据,A应用采集数据发送给B应用处理,B处理后再存储到自己的数据库。

A服务器->B服务器: 刚刚采集到新鲜热乎的数据一份!
Note right of B服务器: 尝一口,扔冰箱里
B服务器-->A服务器: 不错!是挺新鲜的!

方案

  • 方案一、A服务器采集数据后,按照B的需求进行加工处理,扔进B的数据库中。
  • 方案二、A调用B的处理过程,B处理完后存入数据库。这就是远程过程调用(RPC)。

方案一将A、B之间的联动转化为A与B数据库的联动。此方案增加了系统间的耦合,降低了系统的稳定性,增加了维护成本,也带来了安全隐患。方案二A、B之间保持了独立性,减少了相互干扰,提升了稳定性。所以这里采用方案二来实现。

如何使用rpc调用,有两个方面问题:

  • 一、B服务器作为服务提供方,以何种方式提供服务?
  • 二、A服务器作为调用方,如何调用B所提供的服务?

web2py解决方案

一、服务器解决方案

B服务器采用python的web2py作为web服务器框架,在官网我们找到了RPC相关的文档说明,框架提供了多种RPC协议的支持。XMLRPC、JSONRPC、AMFRPC、SOAP等,权衡一下,选择了xmlrpc在调用时不需要再引入第三方库,使用会更方便。
web2py采用了典型的mvc框架,项目里controls目录下对应了所以页面请求的处理函数。修改对应的control文件并添加下面的代码。例:default.py。

@service.xmlrpc
#RPC服务测试函数 ,注:每一个提供服务的函数需要加上@service.xmlrpc作为修饰符
def add(a, b):
    return a + b
    
#开启RPC服务接口
def call():
    session.forget()
    return service()

主要工作分两步,1、添加call函数,开启RPC服务支持。2、为提供RPC服务的函数增加@service.xmlrpc修饰符。
就是这么简单,服务器端的配置就结束了,这里B服务器开启了add服务,将传入的两个参数相加并返回。

二、客户端解决方案

工作很简单,引入xmlrpclib包里的ServerProxy类,传入B服务器的url进行初始化,之后按照对象的方式进行调用。下面是客户端的测试代码。http://127.0.0.1:8000/app/default/call/xmlrpc是B服务器的网络链接地址。

>>> from xmlrpclib import ServerProxy
>>> server = ServerProxy(
       'http://127.0.0.1:8000/app/default/call/xmlrpc')
>>> print server.add(3, 4)
7
>>> print server.add('hello','world')
'helloworld'

通用python网络服务解决方案

web2py作为web服务框架,对基于http协议实现的rpc服务具有天然的优势,服务器不需要再开启其他的网络服务。然而其他提供没有采用web2py框架的服务器该如何提供RPC服务呢。
最近的开发工作中,我们也遇到了这样的问题。此时的B服务器不是web服务器。

一、服务器解决方案

考虑到之前采用了xmlrpc实现远程过程调用,具有了一定的经验,功能上也满足了我们的需求,所以采用搭建xmlrpc服务的方式进行。
在B服务器中添加下面的代码,使用多进程的方式,开启xmlrpc服务器,并绑定到服务器的8088端口。
这里也是提供了add函数作为服务,并返回两个参数相加的接口。

def run_xmlrpcserver():
    from SimpleXMLRPCServer import SimpleXMLRPCServer
    from SocketServer import ThreadingMixIn
    class ThreadXMLRPCServer(ThreadingMixIn, SimpleXMLRPCServer):
        pass

    class MyObject:
        def add(self,a,b):
            return a+b

    obj = MyObject()
    server = ThreadXMLRPCServer(("localhost", 8088), allow_none=True)
    server.register_instance(obj)
    server.serve_forever()
# 开启服务器进程
Process(target=run_xmlrpcserver, args=tuple([ ])).start()

二、客户端解决方案

这里的代码与web2py解决方案中的一致,注意修改下服务的url即可,具体测试代码如下:

>>> server = xmlrpclib.ServerProxy("http://localhost:8088")
>>> words = server.add(1,2)
>>> words
3

总结

最近记性越来越差了,以后要多记录写才好。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 224,896评论 6 522
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 96,283评论 3 402
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 172,085评论 0 367
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 61,010评论 1 300
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 70,015评论 6 400
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,492评论 1 314
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,858评论 3 428
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,829评论 0 279
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,374评论 1 324
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,409评论 3 346
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,527评论 1 355
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,131评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,858评论 3 339
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,296评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,434评论 1 276
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 50,087评论 3 381
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,597评论 2 366

推荐阅读更多精彩内容

  • 远程过程调用(Remote Procedure Call, RPC)是从一台机器上通过参数传递的方式调用另一台机...
    刘惜有阅读 1,098评论 0 1
  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 9,022评论 0 13
  • 1.埋点是做什么的 2.如何进行埋点 3.埋点方案的设计 近期常被问到这个问题,我担心我的答案会将一些天真烂漫的孩...
    lxg阅读 2,022评论 0 1
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,120评论 1 32
  • 个性是这个时代的关键词。先来看几个成功的例子。 今日头条app如今人尽皆知,很多用户喜欢用这款应用阅读自己感兴趣的...
    十六画生的写作阅读 944评论 0 1