文档章节

Python远程方法调用 RPyC

沉淀岁月
 沉淀岁月
发布于 2016/11/16 11:22
字数 649
阅读 48
收藏 0

 

rpyc (Remote Python Call)为分布式计算环境提供了优良的基础平台。 使用rpyc编写c/s结构程序,完全不用考虑老式的socket编程,现在只用编写简单的3、5行代码即可完成以前的数千行代码的功能。

Remote Python Call (RPyC) 是一个 Python 的库用来实现 RPC 和分布式计算的工具。支持同步和异步操作、回调和远程服务以及透明的对象代理。

 

1.写服务器端的方法如下:
#-*- encoding: gb2312 -*-
import time
from rpyc import Service
from rpyc.utils.server import ThreadedServer
class TimeService(Service):
    def exposed_get_time(self):
        return time.ctime()      #time模块中的一个内置方法
s=ThreadedServer(TimeService,port=12233,auto_register=False)
s.start()
RPYC 这个包是我导入的一个外部包的哦!不过通过help一样可以查看到这个包的内在的一些东西哈哈!
2.服务器开启现在来让客户端进行访问了!
import rpyc
c=rpyc.connect('localhost',12233)
c.root.get_time()
c.close()
现 在来想一个事情。之前在RO通讯模块中就是我们在服务器端写了一个方法然后我们就可在客户端直接调用了哦!
比如我们在服务器端写了一个计算sum 函数  然后我们就可以在客户端进行调用这个函数了哦!
那我们来看一下这里的机制吧!
RPYC重点:
1.Client一定要 close()连接哦!
2.Server中exposed_打头的函数才能被 客户端调用。
所以如果写服务端代码的时候想要让客户端调用 就要加这一个前缀哦
c=rpyc.connect('localhost',12233) #首先要连接服务器
3.client要访问服 务器端代码通过c.root才能访问哦!
c.root.get_time()  调用服务器端方法了!
4.RPYC没有认证机制,任何客 户端都可以直接访问服务器端的暴露的方法了!

OK,联系当前在RO中写过的一个方法哦!
import time
from rpyc import Service
from rpyc.utils.server import ThreadedServer
class TimeService(Service):
    def exposed_sum(self,a,b):
        return a+b
s=ThreadedServer(TimeService,port=12233,auto_register=False)
s.start()
我 先在服务器端写了一个方法求和操作!
让客户端进行直接调用 吧!
import rpyc
c=rpyc.connect('localhost',12233)
print c.root.sum(1,2)
c.close()
本质与RO原理是一样的哦!
以后我们只需要在服务器端定义好一些写好的方法 然后在客户端直接调用就可以了!
v=c.root.function()
返回了一个值。如果是字符串,数字,在c.close之后仍然能 够调用的
如果为其他类型则不能访问了!

本文转载自:http://doudouclever.blog.163.com/blog/static/17511231020116263409365/

共有 人打赏支持
沉淀岁月
粉丝 25
博文 257
码字总数 91615
作品 0
朝阳
高级程序员
Python RPC 远程调用脚本之 RPyC 实践

最近有个监控需求,需要远程执行集群每个节点上的脚本,并获取脚本执行结果,为了安全起见不需要账号密码登陆节点主机,要求只需要调用远程脚本模块的方法就能实现。 总结下python进行远程调...

大数据之路
2015/06/28
0
0
python RPC简单调用

1.首先要安装rpyc模块; #pip install rpyc 2.服务端 author = 'Administrator'import rpycfrom rpyc import Servicefrom rpyc.utils.server import ThreadedServerimport osclass Test(Ser......

jk409
2015/03/19
0
0
用 Plumbum 开发 Python 命令行工具

摘要:本文翻译自 Python Plumbum 开源库的官方文档 Plumbum CLI 部分,主要介绍如何使用 Plumbum CLI 工具包来开发 Python 命令行应用程序,这是一个非常 Pythonic、容易使用、功能强大的工...

作者: Tomer Filiba
05/04
0
0
python rpyc的应用 ——聊天的功能(带认证)

rpc:远程过程调用,一个协议,实现的语言有很多。顾名思义,在A机器远程调用B机器里面的函数。rpyc:python的远程过程调用。 首先是安装,我的环境:centos6.5 测试下,运行 没有错误就说明...

vasks
2016/04/01
174
0
Python远程方法调用--RPyC

rpyc (Remote Python Call)为分布式计算环境提供了优良的基础平台。 使用rpyc编写c/s结构程序,完全不用考虑老式的socket编程,现在只用编写简单的3、5行代码即可完成以前的数千行代码的功能...

匿名
2009/03/01
7.4K
0

没有更多内容

加载失败,请刷新页面

加载更多

怎样使用主流缓存更新策略来减少性能消耗?

在互联网项目开发中,缓存的应用是非常普遍了,缓存可以帮助页面提高加载速度,减少服务器或数据源的负载。 一、为什么需要缓存? 一般在项目中,最消耗性能的地方就是后端服务的数据库了。而...

Java干货分享
22分钟前
1
0
杭州云栖大会阿里云放大招,8K远程医疗会诊引关注

大家每天都会照镜子,镜子里的一切都清清楚楚,足可乱真,可是你想过有一天看视频直播就像照镜子么? 这不,在云栖大会的C馆里,8K超高清直播体验馆前异常火爆,在这里,很多参会者都围着有1...

阿里云云栖社区
24分钟前
16
0
C++获取系统盘符极简方法

盘符获取 std::shared_ptr<std::list<wchar_t>> disks(void) {wchar_t data[255];return [&](int length)->std::shared_ptr<std::list<wchar_t>> {auto result = std::make_shared< s......

CHONGCHEN
24分钟前
1
0
Python 操作samba文件服务器

# /usr/bin/env python# -*- coding:utf-8 -*-from smb.SMBConnection import SMBConnectionconn = SMBConnection('root', '123456', 'any', '', use_ntlm_v2 = True)assert conn.......

China丶小可
31分钟前
1
0
vue引入echart.js打包时特别大

link : https://www.cnblogs.com/strinkbug/p/5786222.html 一、i在html中添加script标签如下: <script src="//cdn.bootcss.com/echarts/3.2.2/echarts.simple.min.js"></script> 二、在web......

Js_Mei
34分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部