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

相关推荐
致奋斗的我们6 分钟前
RHCE的学习(7)
linux·服务器·网络·学习·redhat·rhce·rhcsa
hanniuniu1323 分钟前
动态威胁场景下赋能企业安全,F5推出BIG-IP Next Web应用防火墙
网络协议·tcp/ip·安全
Chris-zz1 小时前
Linux:磁盘深潜:探索文件系统、连接之道与库的奥秘
linux·网络·c++·1024程序员节
黑龙江亿林等级保护测评1 小时前
等保行业如何面对新兴安全威胁
网络·安全·金融·智能路由器·ddos
墨染新瑞1 小时前
C语言——网络编程(下)
网络
菜林子2 小时前
【Linux | 网络I/O模型】五种网络I/O模型详解
linux·服务器·网络
IT·小灰灰2 小时前
Python——自动化发送邮件
运维·网络·后端·python·自动化
很透彻2 小时前
【网络】传输层协议UDP
网络·网络协议·udp
黑龙江亿林等级保护测评3 小时前
等保行业如何选择核实的安全防御技术
网络·人工智能·python·安全·web安全·智能路由器·ddos
晓翔仔3 小时前
SSL/TLS 密码套件漏洞分析以及修复方法
服务器·网络·nginx·安全·tomcat·ssl·密码套件