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 ...
随机推荐
- linux 下安装 docker 环境
一分钟了解 Docker Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源.Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然 ...
- 大型情感类技术连续剧-徒手撸一个 uTools(二)
前言 上篇手把手教你实现一个支持插件化的 uTools 工具箱我们介绍过了如何通过 electron 实现 utools 的插件功能体系,并按照 utools 的交互和设计做出了一套可以支持插件化的桌 ...
- k8s通过ceph-csi接入存储的概要分析
kubernetes ceph-csi分析目录导航 概述 下面的分析是k8s通过ceph-csi(csi plugin)接入ceph存储(csi相关组件的分析以rbd为例进行分析),对csi系统结构. ...
- js更改HTML样式
<!DOCTYPE HTML><html><head><meta http-equiv="Content-Type" content=&q ...
- CentOS7详细安装教程(图文)
CentOS7安装过程:(图文详解) 为了做实验,装台Linux的虚拟机,手上有这个7的ISO文件就懒得去下载8的了. 0X01.虚拟机配置 0X02.CentOS7系统配置安装 分别创建/boot区 ...
- 温故知新,CSharp遇见字符串比较(String Comparison),更佳科学的比较字符串
背景 在C#中,我们经常会遇到需要比较字符串的场景,有时候甚至因为外部输入的不确定性,我们需要忽略大小写来进行比较,以达到判断业务的述求. 对字符串用法的建议 使用.NET进行开发时,请遵循以下简要建 ...
- 1、Linux下源码编译安装PostgreSQL
操作系统:Centos7 说明:postgresql必须在postgres用户下初始化数据库和启动,否则报错. PostgreSQL的特性 PostgreSQL是一种几乎可以运行在各种平台上的免费的开 ...
- 【Azure API 管理】解决调用REST API操作APIM(API Management)需要认证问题(Authentication failed, The 'Authorization' header is missing)
问题描述 在通过REST API的方式来管理APIM资源,需要调用Azure提供的management接口.而这所有的接口,都是需要有Token并且还需要正确的Token.如若不然,就会获取到如下的错 ...
- 分布式唯一ID生成方案选型!详细解析雪花算法Snowflake
分布式唯一ID 使用RocketMQ时,需要使用到分布式唯一ID 消息可能会发生重复,所以要在消费端做幂等性,为了达到业务的幂等性,生产者必须要有一个唯一ID, 需要满足以下条件: 同一业务场景要全局 ...
- CentOS-yum安装Redis(单点)
源文件安装(推荐安装) 在CentOS系统中,首先安装EPEL仓库,然后更新yum源: $ yum install epel-release -y $ yum update -y 然后安装Redis数 ...