Python RPC 不会?不妨看看这篇文章
1. 前言
大家好,我是安果!
RPC,全程为 Remote Procedure Call,是一种进程间的通信方式,它采用「 服务端 / 客户机 」模式,是一种请求响应模型
其中,服务端负责提供服务程序、响应请求做具体的实现逻辑,客户机负责请求调用
主流的 RPC 框架包含:
阿里的 Dubbo
Facebook 的 Thrift
Google 的 gRpc
新浪微博的 Motan
Golang 生态的 rpcx
其中,gRpc 和 Thrift 是跨语言的 RPC 服务框架,并且 Thrift 相比性能更高
本篇文章以 Thrift 为例,聊聊 Python 中使用 RPC 的流程
2. thriftpy2 介绍
Thrift 是一种接口描述语言和二进制通讯协议,它可以被用来定义和创建跨语言的服务,使得不同语言的客户端、服务器之间能进行高效透明的通信
thriftpy2 是在 Thrift 的基础上进行二次封装,使用它编写 RPC 更加方便快捷
项目地址:https://github.com/Thriftpy/thriftpy2
首先,我们在虚拟环境下安装依赖包
# 安装依赖
pip3 install thriftpy2
然后,如果是 Windows,建议在 Pycharm 中安装 thrift 插件
PS:该插件可以方便我们编写 Thrift 通讯文件
下载地址:https://plugins.jetbrains.com/plugin/7331-thrift-support
3. 实战一下
首先,根据需求编写 Thrift 通讯文件
比如,该文件定义 2 个方法
无参函数 ping
登录 login
包含两个参数:username、password
# foo.thrift
service PingPong{
string ping(),
string login(
1: string username,
2: string password
)
}
然后,编写服务端代码
根据 Thrift 通讯文件中定义的方法,编写具体的实现逻辑
创建一个服务对象,指定绑定的 ip 地址及端口号,开启服务并监听消息
# rcp_server.py
import thriftpy2
from thriftpy2.rpc import make_server
# 读取通信配置文件
pingpong_thrift = thriftpy2.load("foo.thrift", module_name="pingpong_thrift")
class Dispatcher(object):
"""根据通信配置文件定义的方法,重写实现方法"""
def ping(self):
"""
Ping一下
:return:
"""
return "pong"
def login(self, username, password):
"""
登录
:param username: 用户名
:param password: 密码
:return:
"""
print('获取客户端传过来的参数,用户名:',username,",密码:",password)
return '登录成功!'
# 创建服务,指定本地ip地址及监听端口号
server = make_server(pingpong_thrift.PingPong, Dispatcher(), '192.168.40.217', 9000)
# 开启服务并监听
server.serve()
接着,编写客户端代码
这里,根据服务端提供的 ip 地址、端口号,创建客户端连接对象,调用通信文件中定义好的方法
PS:如果客户端在远程执行,需要将 Thrift 通讯文件放置到同级目录下执行
# rcp_client.py
import thriftpy2
from thriftpy2.rpc import make_client
# 读取通信配置文件
pingpong_thrift = thriftpy2.load("foo.thrift", module_name="pingpong_thrift")
# 创建客户端
client = make_client(pingpong_thrift.PingPong, '192.168.40.217', 9000)
# 调用通信文件中定义好的方法(实际调用服务端的方法)
print(client.ping())
print(client.login('root', 'pwd'))
最后,分别运行服务端和客户端的代码
使用 WireShark 进行抓包分析,能发现服务端和客户端通讯的方式及数据传输过程
WireShark 的使用可以参考这篇文章:
4. 最后
企业项目中,常用的 HTTP 的特点是简单、开发方便,上手简单、是主流的数据传输协议
相比 HTTP 或 H2,RPC 的主要优势体现在安全高、性能消耗低、传输效率高、服务治理方便上,所以我们可以根据实际项目需求选择合理的数据通信方式
如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!
Python RPC 不会?不妨看看这篇文章的更多相关文章
- Docker学不会?不妨看看这篇文章
大家好,我是辰哥! 上一篇文章(2300+字!在不同系统上安装Docker!)教大家如何在系统上安装docker,今天咱们来学习docker的基本使用. 辰哥将在本文里详细介绍docker的各种使用命 ...
- 理解Python中的装饰器//这篇文章将python的装饰器来龙去脉说的很清楚,故转过来存档
转自:http://www.cnblogs.com/rollenholt/archive/2012/05/02/2479833.html 这篇文章将python的装饰器来龙去脉说的很清楚,故转过来存档 ...
- Python RPC 之 gRPC
gRPC 简介: gRPC 是一款高性能.开源的 RPC 框架,产自 Google,基于 ProtoBuf 序列化协议进行开发,支持多种语言(Golang.Python.Java等),本篇只介绍 Py ...
- Python程序的常见错误(收集篇)
关于Python Python是一门解释性的,面向对象的,并具有动态语义的高级编程语言.它高级的内置数据结构,结合其动态类型和动态绑定的特性,使得它在快速应用程序开发(Rapid Applicatio ...
- Python之路【第十九篇】:爬虫
Python之路[第十九篇]:爬虫 网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用 ...
- Python之路【第十八篇】:Web框架们
Python之路[第十八篇]:Web框架们 Python的WEB框架 Bottle Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Pytho ...
- Python之路【第十六篇】:Django【基础篇】
Python之路[第十六篇]:Django[基础篇] Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...
- Python之路【第十五篇】:Web框架
Python之路[第十五篇]:Web框架 Web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. 1 2 3 4 5 6 ...
- fw:学好Python必读的几篇文章
学好Python必读的几篇文章 from:http://blog.csdn.net/hzxhan/article/details/8555602 分类: python2013-01-30 11:52 ...
随机推荐
- kubelet分析-pvc扩容源码分析
kubernetes ceph-csi分析目录导航 存储的扩容分为controller端操作与node端操作两大步骤,controller端操作由external-resizer来调用ceph完成,而 ...
- 使用A Star 算法实现自动寻路详解
@ 目录 1.什么是A Start算法 2.A Star算法的原理和流程 2.1 前提 2.1.1 从起点开始扩散的节点 2.1.2 最短距离计算公式:F = G + H 2.1.3 欧几里得距离计算 ...
- Linux运维网络基础
1.网络架构的三个层次 核心层: 路由器(网关接口) 实现和外网通讯 冗余能力(主备) 汇聚层: 交换机(三层交换机) 冗余能力 策略控制能力 接入层: 交换机(二层交换机) 终端设备接入网络 2.网 ...
- Gym 100783C Golf Bot FFT
大致题意: 给你N个整数和M个整数,问这M个数中,有几个数可以表达成那N个整数中一个或者两个整数的和. 分析: 算是半个裸的FFT.FFT可以用来在nlongn时间内求高精度乘法,我们先模拟一下乘法. ...
- AvtiveMQ与SpringBoot结合
首先来了解下ActivieMQ的应用场景,消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题.实现高性能,高可用,可伸缩和最终一致性架构是大型分布式系统不可缺少的中间件 ...
- 包机制与javaDOC文档
包机制 包的本质就是个文件夹: 一般利用公司域名倒置作为包名:com.kuangstudy.biog javaDOC文档 package com.kuang.base; /** * @author K ...
- 你真的懂 export default 吗?
export default A 和 export { A as default } 乍一看是一样的,但是里面有一些细微的区别比较容易留坑.本文介绍两种写法的不同之处. import 语句导入的是引用 ...
- Raspberry Pi:树莓派开发板配置USB启动系统
准备材料 树莓派4B U盘 TF卡 树莓派基础镜像2020-08-20稳定版(这个系统是必须的并拷录在TF卡) Kali树莓派系统(这个是我想要学习的系统,大家可以准备自己的系统,拷录在U盘的) SD ...
- SpringCloud:feign对象传参和普通传参及遇到的坑
对象传参: #使用@RequestBody来指定传参对象 @RequestMapping(value = "/v2/matterCode/genCode", method = Re ...
- 基于js的姓名校验
// 姓名校验 isRightName: function(name) { var reg = /^[a-zA-Z\u4E00-\u9FA5\uF900-\uFA2D\u00B7\u2022\u009 ...