python rpyc客户端调用服务端方法的注意说明

 更新时间:2022年06月18日 10:11:37   作者:Riven_h  
这篇文章主要介绍了python rpyc客户端调用服务端方法的注意说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

python rpyc客户端调用服务端方法

使用rpyc遇到两个问题:

问题1

client调用server的exposed_xxxx()方法时传进去的参数类型,到了server端会改变,

打印出来是<netref class 'rpyc.core.netref.type'>类型,与原来传进的类型不同

解决方法:

def exposed_clentA_will_use(self, hello):
    hello = rpyc.classic.obtain(hello)

这样就把传进来的hello转变为本地类型,如果本地没有这种类型,需要创建这种类型

比如传进来的是<class 'numpy.ndarray'>类型,但是server本地没有,则需要import numpy

问题2

client调用server的方法时有报错ValueError: pickling is disabled

解决方法:

rpyc_config = rpyc.core.protocol.DEFAULT_CONFIG
rpyc_config['allow_pickle'] = True 
host_ip = '127.0.0.1' 
conn = rpyc.connect(host_ip, port = 33333, config = rpyc_config)

由于是不安全的协议,需要手动允许pickle

字面意思也明确了:allow_pickle

python rpyc的使用心得

6月份,在公司做APP和Web自动化测试开发,碰到一个比较棘手的问题是:APP需要和Web一起操作才能走完整个测试流程。

但是APP和Web使用的是不同的测试工具,Appium和Selenium,测试框架也是独立的。如何把二者整合起来呢?

没错,python rpyc模块派上用场了,这里使用python rpyc对Web页面相关的操作做了二次封装。

from rpyc import Service
from rpyc.utils.server import ThreadedServer
class MyService(Service):
    def exposed_bid(xxx):
        back_page.bid(xxx)

s=ThreadedServer(MyService,port=12233,listener_timeout=300,auto_register=False)
s.start()

在APP自动化测试脚本里面,这样调用即可:

c = rpyc.connect('localhost',12233)
c.root.bid(xxxx)

但是在APP测试脚本运行过程中,会出现rpyc调用超时的情况,这是因为rpyc默认的调用等待时间只有30s,如果某些rpyc调用的等待时间超过30s就会报错,解决方法很简单,在rpyc包的protocol.py文件中找到
SYNC_REQUEST_TIMEOUT,改大即可。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • python如何读取bin文件并下发串口

    python如何读取bin文件并下发串口

    这篇文章主要介绍了python如何读取bin文件并下发串口,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • Django 再谈一谈json序列化

    Django 再谈一谈json序列化

    这篇文章主要介绍了Django json序列化,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • Django 创建后台,配置sqlite3教程

    Django 创建后台,配置sqlite3教程

    今天小编就为大家分享一篇Django 创建后台,配置sqlite3教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • 深入理解Python中命名空间的查找规则LEGB

    深入理解Python中命名空间的查找规则LEGB

    这篇文章主要介绍了深入理解Python中命名空间的查找规则LEGB,作者根据Python3.x版本进行讲解,需要的朋友可以参考下
    2015-08-08
  • 构建Python中的分布式系统结合Celery与RabbitMQ

    构建Python中的分布式系统结合Celery与RabbitMQ

    在本文中,我们深入探讨了如何利用Celery和RabbitMQ构建Python中的分布式系统,我们首先介绍了Celery和RabbitMQ的概念及其优势,然后展示了如何结合它们来创建一个简单但功能强大的分布式系统,感兴趣的朋友跟随小编一起看看吧
    2024-05-05
  • Python中DataFrame判断两列数据是否相等的方法

    Python中DataFrame判断两列数据是否相等的方法

    本文主要介绍了DataFrame判断两列数据是否相等的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • python实现雨滴下落到地面效果

    python实现雨滴下落到地面效果

    这篇文章主要为大家详细介绍了python实现雨滴下落到地面效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • Python使用pandas处理CSV文件的实例讲解

    Python使用pandas处理CSV文件的实例讲解

    今天小编就为大家分享一篇Python使用pandas处理CSV文件的实例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • 详解如何理解并正确使用Python中的f字符串

    详解如何理解并正确使用Python中的f字符串

    Python中的f字符串是一种字符串格式化语法,它可以将变量、表达式和函数等动态地嵌入到字符串中,本文就来详细讲讲如何理解并正确使用它吧
    2023-06-06
  • Python实现网络通信的HTTP请求Socket编程Web爬虫方法探索

    Python实现网络通信的HTTP请求Socket编程Web爬虫方法探索

    随着互联网的不断发展,Python作为一门多用途的编程语言,提供了强大的工具和库来进行网络连接和通信,本文将深入探讨Python中连接网络的方法,包括HTTP请求、Socket编程、Web爬虫和REST API的使用
    2024-01-01

最新评论