Python远程方法调用实现过程解析


Posted in Python onJuly 28, 2020

RPCHandler 和 RPCProxy 的基本思路是很比较简单的。 如果一个客户端想要调用一个远程函数,比如 foo(1, 2, z=3) ,代理类创建一个包含了函数名和参数的元组 (‘foo', (1, 2), {‘z': 3}) 。 这个元组被pickle序列化后通过网络连接发生出去。 这一步在 RPCProxy 的 getattr() 方法返回的 do_rpc() 闭包中完成。

服务器接收后通过pickle反序列化消息,查找函数名看看是否已经注册过,然后执行相应的函数。 执行结果(或异常)被pickle序列化后返回发送给客户端。实例需要依赖 multiprocessing 进行通信。 不过,这种方式可以适用于其他任何消息系统。例如,如果你想在ZeroMQ之上实习RPC, 仅仅只需要将连接对象换成合适的ZeroMQ的socket对象即可。

先实现server端

import json
from multiprocessing.connection import Listener
from threading import Thread


class RPCHandler:
  def __init__(self):
    self._functions = {}

  def register_function(self, func):
    self._functions[func.__name__] = func

  def handle_connection(self, connection):
    try:
      while True:
        func_name, args, kwargs = json.loads(connection.recv())
        # Run the RPC and send a response
        try:
          r = self._functions[func_name](*args, **kwargs)
          connection.send(json.dumps(r))
        except Exception as e:
          connection.send(json.dumps(e))
    except EOFError:
      pass


def rpc_server(handler, address, authkey):
  sock = Listener(address, authkey=authkey)
  while True:
    client = sock.accept()
    t = Thread(target=handler.handle_connection, args=(client,))
    t.daemon = True
    t.start()
# Some remote functions
def add(x,y):
  return x+y


if __name__ == '__main__':
  handler = RPCHandler()
  handler.register_function(add)
  # Run the server
  rpc_server(handler, ('127.0.0.1', 17000), authkey=b'peekaboo')

再实现client端

import json
from multiprocessing.connection import Client


class RPCProxy:

  def __init__(self, connection):
    self._connection = connection

  def __getattr__(self, name):
    def do_rpc(*args, **kwargs):
      self._connection.send(json.dumps((name, args, kwargs)))
      result = json.loads(self._connection.recv())
      if isinstance(result, Exception):
        raise result
      return result

    return do_rpc
if __name__ == '__main__':
  c = Client(('127.0.0.1', 17000), authkey=b'peekaboo')
  proxy = RPCProxy(c)
  res = proxy.add(2, 3)
  print(res)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在SAE上部署Python的Django框架的一些问题汇总
May 30 Python
python 删除大文件中的某一行(最有效率的方法)
Aug 19 Python
python2.7+selenium2实现淘宝滑块自动认证功能
Feb 24 Python
Python利用pandas计算多个CSV文件数据值的实例
Apr 19 Python
selenium在执行phantomjs的API并获取执行结果的方法
Dec 17 Python
python实现贪吃蛇游戏
Mar 21 Python
Python模拟百度自动输入搜索功能的实例
Feb 14 Python
Tensorflow模型实现预测或识别单张图片
Jul 19 Python
python tkinter实现彩球碰撞屏保
Jul 30 Python
python-OpenCV 实现将数组转换成灰度图和彩图
Jan 09 Python
关于Python 中的时间处理包datetime和arrow的方法详解
Mar 19 Python
详解Python IO编程
Jul 24 Python
Python 实现一个计时器
Jul 28 #Python
python爬虫要用到的库总结
Jul 28 #Python
Python常用类型转换实现代码实例
Jul 28 #Python
Python 如何创建一个线程池
Jul 28 #Python
matplotlib subplot绘制多个子图的方法示例
Jul 28 #Python
python爬虫用mongodb的理由
Jul 28 #Python
python爬虫数据保存到mongoDB的实例方法
Jul 28 #Python
You might like
让你的PHP同时支持GIF、png、JPEG
2006/10/09 PHP
main.php
2006/12/09 PHP
Laravel使用原生sql语句并调用的方法
2019/10/09 PHP
JS JavaScript获取Url参数,src属性参数
2021/03/09 Javascript
JavaScript去除空格的几种方法
2006/10/03 Javascript
一个报数游戏js版(约瑟夫环问题)
2010/08/05 Javascript
js取滚动条的尺寸的函数代码
2011/11/30 Javascript
document节点对象的获取方式示例介绍
2013/12/24 Javascript
JavaScript实现图片滑动切换的代码示例分享
2016/03/06 Javascript
js多功能分页组件layPage使用方法详解
2016/05/19 Javascript
JavaScript函数中关于valueOf和toString的理解
2016/06/14 Javascript
jQuery动态添加可拖动元素完整实例(附demo源码下载)
2016/06/21 Javascript
Bootstrap3 datetimepicker控件使用实例
2016/12/13 Javascript
a标签置灰不可点击的实现方法
2017/02/06 Javascript
jQuery获取Table某列的值(推荐)
2017/03/03 Javascript
ES6中Array.copyWithin()函数的用法实例详解
2017/09/16 Javascript
详解vue填坑之解决部分浏览器不支持pushState方法
2018/07/12 Javascript
JS中的继承操作实例总结
2020/06/06 Javascript
three.js欧拉角和四元数的使用方法
2020/07/26 Javascript
[41:12]Liquid vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.24
2019/09/10 DOTA
Python的高级Git库 Gittle
2014/09/22 Python
Python利用多进程将大量数据放入有限内存的教程
2015/04/01 Python
python获取外网ip地址的方法总结
2015/07/02 Python
详解Django中的form库的使用
2015/07/18 Python
Python 使用os.remove删除文件夹时报错的解决方法
2017/01/13 Python
利用Python实现Windows下的鼠标键盘模拟的实例代码
2017/07/13 Python
Python实现的栈、队列、文件目录遍历操作示例
2019/05/06 Python
python实现函数极小值
2019/07/10 Python
python GUI库图形界面开发之PyQt5布局控件QHBoxLayout详细使用方法与实例
2020/03/06 Python
Python绘图之柱形图绘制详解
2020/07/28 Python
高中毕业生自我鉴定例文
2013/12/29 职场文书
代办社保委托书范文
2014/10/06 职场文书
财务稽核岗位职责
2015/04/13 职场文书
jquery插件实现代码雨特效
2021/04/24 jQuery
MySQL 那些常见的错误设计规范,你都知道吗
2021/07/16 MySQL
关于pytest结合csv模块实现csv格式的数据驱动问题
2022/05/30 Python