(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")

相关推荐
.Shu.4 小时前
计算机网络 TLS握手中三个随机数详解
网络·计算机网络·安全
于冬恋12 小时前
RabbitMQ高级
服务器·网络·rabbitmq
tan77º14 小时前
【Linux网络编程】分布式Json-RPC框架 - 项目设计
linux·服务器·网络·分布式·网络协议·rpc·json
.Shu.14 小时前
计算机网络 各版本TLS握手的详细过程
网络·计算机网络
半路_出家ren14 小时前
路由综合实验RIP,OSPF,BGP
网络·网络协议·rip·ospf·ebgp·ibgp
张太行_16 小时前
网络SSL/TLS协议详解
网络·web安全·ssl
重启的码农16 小时前
NAT穿透技术:原理、实现与应用全景解析
网络协议
zhysunny16 小时前
Day22: Python涡轮增压计划:用C扩展榨干最后一丝性能!
c语言·网络·python
hhzz16 小时前
重温 K8s 基础概念知识系列八( K8S 高级网络)
网络·容器·kubernetes
VVVVWeiYee19 小时前
TCP/UDP详解(一)
运维·网络·tcp/ip·udp·信息与通信