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

(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 SimpleXMLRPCServer

class calculate:
    def add(self, x, y):
        return x + y

    def multiply(self, x, y):
        return x * y

    def subtract(self, x, y):
        return abs(x-y)

    def divide(self, x, y):
        return x/y


obj = calculate()
server = SimpleXMLRPCServer(("localhost", 8088))
# 将实例注册给rpc server
server.register_instance(obj)

print("Listening on port 8088")
server.serve_forever()

客户端:

from xmlrpc import client

server = 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.kler.cn/a/372689.html

相关文章:

  • 网络搜索引擎Shodan(2)
  • GRE Over IPsec(华三)
  • Java阶段三01
  • spring-第十一章 注解开发
  • 第8天:数据存储-补充材料——MainActivity.kt解读
  • Python+Selenium+Pytest+POM自动化测试框架封装(完整版)
  • Comsol基于亥姆霍兹声学超材料的通风式低频吸声器
  • 【Linux】文件切割排序 cut sort
  • 微信小程序元素水平居中或垂直居中
  • vue打包项目直接输出压缩包,方便部署线上
  • HCIP-HarmonyOS Application Developer V1.0 笔记(二)
  • 问题记录01
  • Oracle视频基础1_1.1练习
  • C# 企业微信机器人推送消息 windows服务应用程序的使用
  • ComfyUI - ComfyUI 工作流中集成 SAM2 + GroundingDINO 处理图像与视频 教程
  • docker-高级(待补图)
  • 百度SEO中的关键词密度与内容优化研究【百度SEO专家】
  • 职业技术学校新出路,无人机飞手考证、组装、调试全面提高市场就业率
  • Qt:信号和槽
  • leetcode动态规划(二十三)-打家劫舍III
  • 【Python学习计算机知识储备】
  • 如何从多个方面进行oracle数据库存储过程优化?
  • 【QNAP威联通NAS系统恢复进阶教程】如果 .conf 和 md9 无法自动组装,如何恢复 NAS?
  • hive 异常任务中间数据清理
  • 数据结构与算法分析——你真的理解查找算法吗——二叉查找树(代码详解)
  • 论文阅读:三星-TinyClick