当前位置: 首页 > news >正文

(done) 什么 RPC 协议? remote procedure call 远程调用协议

来源:https://www.bilibili.com/video/BV1Qv4y127B4/?spm_id_from=333.337.search-card.all.click&vd_source=7a1a0bc74158c6993c7355c5490fc600


可以理解为,调用远程服务器上的一个方法/函数/服务的方式,同时隐藏网络细节

一个 python3 的 RPC 例子如下 (服务端和客户端都在本地) :

服务端:

from xmlrpc.server import SimpleXMLRPCServerclass calculate:def add(self, x, y):return x + ydef multiply(self, x, y):return x * ydef subtract(self, x, y):return abs(x-y)def divide(self, x, y):return x/yobj = calculate()
server = SimpleXMLRPCServer(("localhost", 8088))
# 将实例注册给rpc server
server.register_instance(obj)print("Listening on port 8088")
server.serve_forever()

客户端:

from xmlrpc import clientserver = client.ServerProxy("http://localhost:8088")>> server.add(2, 3)
5
>>> server.multiply(2, 3)
6
>>> server.subtract(2, 3)
1
>>> server.divide(2, 3)
0

如果要让服务端和客户端在两个不同的机器上的话,服务端的这行代码

server = SimpleXMLRPCServer(("localhost", 8088))

得写成:

server = SimpleXMLRPCServer(("serverIP", 8088))

客户端的这行代码

server = client.ServerProxy("http://localhost:8088")

得写成

server = client.ServerProxy("http://serverIP:8088")


http://www.mrgr.cn/news/59225.html

相关文章:

  • 强大!Spring Boot 3.3 集成 PDFBox 轻松实现电子签章功能!
  • OAK相机的RGB-D彩色相机去畸变做对齐
  • uniapp路由权限拦截守卫
  • UE5蓝图中整理节点的方法
  • Python自动化测试+邮件推送+企业微信推送+Jenkins
  • 单臂交换知识点
  • 无告知搜索算法(Python)
  • FCN深度学习语义分割开山之作——学习笔记
  • 更强的可操作性!Midjourney两大重要功能更新!
  • STL二分查找
  • 3285. 找到稳定山的下标
  • Qt的信号槽机制学习一
  • 常见存储器及其特点
  • 【C++习题】12.滑动窗口_将 x 减到 0 的最小操作数
  • vue3+vite 部署npm 包
  • PG数据库之事务处理
  • CANFD SSP第二采样点引发的“风波”分析
  • 数据结构------手撕链表(一)【不带头单向非循环】
  • STM32-HAL库 HC-SR04超声波测距 -- 2024.10.26
  • C++基础:三个字符串也能搞大小?
  • 谈谈你对AQS的理解
  • 百度智能云推出11.11活动,各大云厂商香港服务器优惠活动汇总
  • Spark 基础操作
  • 线程安全-同步与互斥/死锁
  • 读取文件内容,并按数学成绩排名,之后输出显示
  • linux学习笔记 Ubuntu下的守护进程supervisor安装与多项目部署