python thrift 实现 单端口多服务的过程


Posted in Python onJune 08, 2020

Thrift 是一种接口描述语言和二进制通信协议。以前也没接触过,最近有个项目需要建立自动化测试,这个项目之间的微服务都是通过 Thrift 进行通信的,然后写自动化脚本之前研究了一下。

需要定义一个xxx.thrift的文件, 来生成各种语言的代码,生成之后我们的服务提供者和消费者,都需要把代码引入,服务端把代码实现,消费者直接使用API的存根,直接调用。

和 http 相比,同属于应用层,走 tcp 协议。Thrift 优势在于发送同样的数据,request包 和 response包 要比 http 小很多,在整体性能上要优于 http 。

前言

学习了两天thrift 一直想实现单端口多服务 但是苦于网上的 thrift 实在太少 而且大部分都是java实现的 最后 改了一个java的 实现了 单端口多服务

实现过程

1 创建 thrift 文件 添加两个服务 Transmit Hello_test

service Transmit {
string invoke(1:i32 cmd 2:string token 3:string data)
}

service Hello_test {
string hello(1: string name)
}

2 运行 thrift.exe -out gen-py --gen py test.thrift

生成对应接口 因为我的 服务端和 用户端 都是用 python写的 所以 只需要 生成python 接口即可

3 编写 server.py

# 服务类1 TransmitHandler
class TransmitHandler:
 def __init__(self):
  self.log = {}

 def invoke(self, cmd, token, data):
  cmd = cmd
  token = token
  data = data
  if cmd == 1:
	  return data + 'and' + token
  else:
   return 'cmd不匹配'
# 服务类2 HelloHandler
class HelloHandler:
	def hello(self, name):
		return 'hello'+name

4 编写服务端运行代码 开启服务端

from test import Transmit
from test import Hello_test

from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
from thrift.server import TServer
# 导入
from thrift.TMultiplexedProcessor import TMultiplexedProcessor
from TransmitHandler_server import TransmitHandler
from Hello_server import HelloHandler


# open server
if __name__ == "__main__":
 # 实现 单端口 多服务 的方法

 transmit_handler = TransmitHandler()
 transmit_processor = Transmit.Processor(transmit_handler)

 hello_handler = HelloHandler()
 hello_processor = Hello_test.Processor(hello_handler)

 transport = TSocket.TServerSocket('127.0.0.1', 8000)
 tfactory = TTransport.TBufferedTransportFactory()
 pfactory = TBinaryProtocol.TBinaryProtocolFactory()
 # 多 processor
 processor = TMultiplexedProcessor()
 processor.registerProcessor('transmit', transmit_processor)
 processor.registerProcessor('hello', hello_processor)

 server = TServer.TSimpleServer(processor, transport, tfactory, pfactory)
 print("Starting python server...")
 server.serve()

值得注意的是 要想实现单端口 多服务 就必须得
引入processor = TMultiplexedProcessor()
用来注册两个服务类
processor.registerProcessor(‘name', procress对象)
name 属性将会在client 时用到

5运行 runserver.py

如果出现Starting python server… 则运行成功

6 编写client.py

from test import Transmit
from test import Hello_test
from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
from thrift.protocol.TMultiplexedProtocol import TMultiplexedProtocol


if __name__ == '__main__':
	# 启动 服务
	transport = TSocket.TSocket('127.0.0.1', 8000)
	transport = TTransport.TBufferedTransport(transport)
	protocol = TBinaryProtocol.TBinaryProtocol(transport)

	# 注册两个protocol 如果想要实现单端口 多服务 就必须使用 TMultiplexedProtocol
	transmit_protocol = TMultiplexedProtocol(protocol, 'transmit')
	hello_protocol = TMultiplexedProtocol(protocol, 'hello')

	# 注册两个客户端
	transmit_client = Transmit.Client(transmit_protocol)
	hello_client = Hello_test.Client(hello_protocol)

	transport.open() # 打开链接
	
	# 测试服务1
	cmd = 1
	token = '1111-2222-3333-4444'
	data = "kong_ge"
	msg = transmit_client.invoke(cmd, token, data)
	print(msg)
	
	# 测试服务2
	name = '孔格'
	msg2 = hello_client.hello(name)
	print(msg2)
	
	# 关闭
	transport.close()

7运行client

观察结果 实现单端口多服务

总结

核心就是 TMultiplexedProcessor 类 和 TMultiplexedProtocol
但是网上关于 thrift python的实例 太少了 导致浪费了很长时间
通过这篇文章的学习很快的明白thrift 中的一些概念

到此这篇关于python thrift 实现 单端口多服务的过程的文章就介绍到这了,更多相关python thrift单端口多服务内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Django中使用group_by的方法
May 26 Python
Python教程之全局变量用法
Jun 27 Python
Python使用sorted排序的方法小结
Jul 28 Python
Python使用matplotlib绘制多个图形单独显示的方法示例
Mar 14 Python
python spyder中读取txt为图片的方法
Apr 27 Python
django反向解析URL和URL命名空间的方法
Jun 05 Python
对python 命令的-u参数详解
Dec 03 Python
Python Pandas 箱线图的实现
Jul 23 Python
在 Jupyter 中重新导入特定的 Python 文件(场景分析)
Oct 27 Python
Tensorflow的常用矩阵生成方式
Jan 04 Python
将pytorch转成longtensor的简单方法
Feb 18 Python
python中sys模块是做什么用的
Aug 16 Python
Python astype(np.float)函数使用方法解析
Jun 08 #Python
python opencv 实现读取、显示、写入图像的方法
Jun 08 #Python
python:删除离群值操作(每一行为一类数据)
Jun 08 #Python
pyecharts在数据可视化中的应用详解
Jun 08 #Python
python numpy实现rolling滚动案例
Jun 08 #Python
Python如何向SQLServer存储二进制图片
Jun 08 #Python
python求numpy中array按列非零元素的平均值案例
Jun 08 #Python
You might like
php+mysql删除指定编号员工信息的方法
2015/01/14 PHP
使用JavaScript创建新样式表和新样式规则
2016/06/14 PHP
php 解决substr()截取中文字符乱码问题
2016/07/18 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
phpStorm+XDebug+chrome 配置详解
2019/04/01 PHP
jQuery 性能优化手册 推荐
2010/02/23 Javascript
jquery tab标签页的制作
2010/05/10 Javascript
在JQuery dialog里的服务器控件 事件失效问题
2010/12/08 Javascript
jQuery中:image选择器用法实例
2015/01/03 Javascript
js中日期的加减法
2015/05/06 Javascript
JavaScript简单下拉菜单特效
2016/09/13 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
ionic实现下拉刷新载入数据功能
2017/05/11 Javascript
JavaScript简单实现合并两个Json对象的方法示例
2017/10/16 Javascript
ionic使用angularjs表单验证(模板验证)
2018/12/12 Javascript
JS实现判断有效的数独算法示例
2019/02/25 Javascript
Angular使用ControlValueAccessor创建自定义表单控件
2019/03/08 Javascript
一文快速了解JQuery中的AJAX
2019/05/31 jQuery
vue父子组件通信的高级用法示例
2019/08/29 Javascript
JS实现滑动拼图验证功能完整示例
2020/03/29 Javascript
从源码角度来回答keep-alive组件的缓存原理
2021/01/18 Javascript
[02:24]DOTA2亚洲邀请赛 NAVI战队出场宣传片
2015/02/07 DOTA
[57:59]EG vs Secret 2018国际邀请赛淘汰赛BO3 第一场 8.22
2018/08/23 DOTA
python绘制圆柱体的方法
2018/07/02 Python
numpy中loadtxt 的用法详解
2018/08/03 Python
python提取具有某种特定字符串的行数据方法
2018/12/11 Python
Jupyter notebook如何修改平台字体
2020/05/13 Python
Python经典五人分鱼实例讲解
2021/01/04 Python
Unix如何添加新的用户
2014/08/20 面试题
大学同学聚会邀请函
2014/01/19 职场文书
医学生自我评价
2014/01/27 职场文书
暂停营业通知
2015/04/25 职场文书
2015年青年志愿者协会工作总结
2015/04/27 职场文书
公司表扬信格式
2015/05/04 职场文书
LayUI+Shiro实现动态菜单并记住菜单收展的示例
2021/05/06 Javascript
Java 中的 Lambda List 转 Map 的多种方法详解
2022/07/07 Java/Android