(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 例子如下 (服务端和客户端都在本地) :

服务端:

python 复制代码
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()

客户端:

python 复制代码
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

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

python3 复制代码
server = SimpleXMLRPCServer(("localhost", 8088))

得写成:

python 复制代码
server = SimpleXMLRPCServer(("serverIP", 8088))

客户端的这行代码

python3 复制代码
server = client.ServerProxy("http://localhost:8088")

得写成

python3 复制代码
server = client.ServerProxy("http://serverIP:8088")

相关推荐
元亓亓亓14 分钟前
考研408--计算机网络--day6--局域网&IEEE802&VLAN
网络·计算机网络·考研·vlan·局域网·ieee
dragoooon3422 分钟前
[Linux网络基础——Lesson11.「NAT & 代理服务 & 内网穿透」]
linux·网络·智能路由器
#微爱帮#23 分钟前
微爱帮监狱寄信写信平台HTTPS隐私保护方案
网络协议·http·https·监狱寄信·监狱写信
自己的九又四分之三站台27 分钟前
Sniffnet 是什么
网络
dragoooon3432 分钟前
[Linux网络基础——Lesson10.「数据链路层 & ARP 具体过程 & ARP 欺骗」]
linux·网络·网络协议
xing.yu.CTF34 分钟前
ATT&CK实战系列--蓝队防御(三)
网络·安全·web安全·横向移动·内网对抗
Dovis(誓平步青云)35 分钟前
《Linux 网络实战手册:从 TCP/IP 协议栈到 UDP网络通信》
linux·网络·tcp/ip
不悔哥40 分钟前
路由器特性——网络状态检测
linux·c语言·网络·tcp/ip·智能路由器
win10系统43 分钟前
网络速度慢、频繁断网的解决办法
网络·智能路由器
初圣魔门首席弟子43 分钟前
HTTP 服务器项目学习笔记
网络