python3和grpc的微服务探索实践
对于微服务的实践,一般都是基于Java和Golang的,博主最近研究了下基于Python的微服务实践,现在通过一个简单的服务来分析Python技术栈的微服务实践
技术栈:Python3 + grpc + Zookeeper
服务API:通过学科获取相应的题型
grpc:由Google公司开源的高性能RPC框架,消息协议使用Google自家开源的Protocol Buffers协议机制,传输使用HTTP2.0标准,支持双向流和连接多路复用
Protocol Buffers部分:
syntax = "proto3";
message Subject {
string name = 1;
}
message QuestionType {
string name = 1;
}
service SimpleRpcServer {
// server streaming rpc
// 客户端发送学科,服务端多次返回该学科包含的题型
rpc GetSubjectQuestionTypes (Subject) returns (stream QuestionType) {
}
}
这里定义grpc的接口类型为服务器流式RPC,即客户端发起一次请求,服务器可以返回多个响应信息,典型的例子有:客户端向服务端发送一个股票代码,服务端就把该股票的实时数据源源不断的返回给客户端:

通过protobuf编译器和Protocol Buffers生成代码:
python3 -m grpc_tools.protoc -I. --python_out=.. --grpc_python_out=.. simple_calculate.proto
服务端开启服务器,对外提供rpc调用流程:

客户端rpc调用流程:

Zookeeper服务注册与发现策略:
服务注册:
def register_zk(host, port):
"""
注册到zookeeper
"""
zk = KazooClient(hosts='{host}:{port}'.format(
host=settings_info["zookeeper"]["host"],
port=settings_info["zookeeper"]["port"])
)
zk.start()
zk.ensure_path('/rpc_calc') # 创建根节点
value = json.dumps({'host': host, 'port': port}) # 创建服务子节点
zk.create(
'/rpc_calc/calculate_server',
value.encode(),
ephemeral=True,
sequence=True
)
服务治理发现:
def _get_servers(self, event=None):
"""
从zookeeper获取服务器地址信息列表
"""
servers = self._zk.get_children(
'/rpc_calc', watch=self._get_servers
)
print(servers)
self._servers = []
for server in servers:
data = self._zk.get('/rpc_calc/' + server)[0]
if data:
addr = json.loads(data.decode())
self._servers.append(addr) def get_server(self):
"""
随机选出一个可用的服务器
"""
return random.choice(self._servers)
服务端实现代码:
class SimpleRpcServerServicer(calculate_grpc.SimpleRpcServerServicer):
"""
实现被调用方法的具体代码
""" def __init__(self):
self.subject_question_type_db = {
'Chinese': ['单选', '多选', '填空', '解答', '问答', '作文'],
'Math': ['单选', '填空', '解答'],
'English': ['单选', '填空', '作文'],
'Physics': ['单选', '多选', '填空', '解答'],
'Chemistry': ['单选', '多选', '填空', '解答'],
'Biology': ['单选', '多选', '填空', '解答'],
'History': ['单选', '多选', '填空', '解答', '问答']
} def GetSubjectQuestionTypes(self, request, context):
"""
服务器流式RPC调用 根据subject获取question_types
:param request:
:param context:
:return:
"""
subject = request.name
question_types = self.subject_question_type_db.get(subject)
for question_type in question_types:
yield calculate_pb2.QuestionType(name=question_type)
客户端实现代码:
def invoke_get_subject_question_types(stub):
"""
根据学科获取题型
Server Streaming RPC 服务器流式RPC 客户端发送,服务器响应多个
:param stub:
:return:
"""
subject = calculate_pb2.Subject(name='Chinese')
question_types = stub.GetSubjectQuestionTypes(subject)
for question_type in question_types:
print(question_type.name)
服务测试:
开启三个服务,地址分别是 host:8003 host:8005 host:8009,客户端开启两个,client1 和 client2 ,测试结果:


已经成功注册了三个server到Zookeeper,客户端1使用的是8003端口的server,客户端2使用的是8005端口的server;grpc框架对于完整的rpc实现来说,实质上是封装了 网络传输、数据协议的打包解包,使得实现rpc更加简单,其本质仍然是遵守rpc的实现原理的
完整的代码详见我的git:simple_calculate_service
python3和grpc的微服务探索实践的更多相关文章
- 基于 Docker 的微服务架构实践
本文来自作者 未闻 在 GitChat 分享的{基于 Docker 的微服务架构实践} 前言 基于 Docker 的容器技术是在2015年的时候开始接触的,两年多的时间,作为一名 Docker 的 D ...
- 闲聊 “今日头条Go建千亿级微服务的实践”
背景 今天跟同事偶然看到<今日头条Go建千亿级微服务的实践>文章,故做了一些探讨,与大家分享下,也欢迎大家多多共同探讨!. 其他资料: 如何理解 Golang 中“不 ...
- 微服务架构实践 - 你只懂docker与spring boot就够了吗?
微服务架构实践 - 你只懂docker与spring boot就够了吗? 作者 浮云发发 已关注 2017.02.27 02:50* 字数 2613 阅读 2583评论 6喜欢 35赞赏 2 微服务并 ...
- NET Core 2.0 微服务跨平台实践
NET Core 2.0 微服务跨平台实践 相关博文: Ubuntu 简单安装 Docker Mac OS.Ubuntu 安装及使用 Consul Consul 服务注册与服务发现 Fabio 安装和 ...
- 今日头条Go建千亿级微服务的实践
今日头条Go建千亿级微服务的实践_36氪 http://36kr.com/p/5073181.html
- 微服务优化之使用gRPC做微服务的内部通信
使用gRPC做微服务的内部通信 gRPC是一个由Google开源的远程服务调用框架,具有多路复用和双向流式通信的特性. 大家好,在本文中将为大家介绍为什么我们应该使用gRPC代替RESTful或JSO ...
- 基于 Spring Cloud 的微服务架构实践指南(下)
show me the code and talk to me,做的出来更要说的明白 本文源码,请点击learnSpringCloud 我是布尔bl,你的支持是我分享的动力! 一.引入 上回 基于 S ...
- 如何基于gRPC沟通微服务框架
本文我们来讲解一下如何使用 gRPC构建微服务,gRPC是一个开源框架,可用于构建可扩展且高性能的微服务并创建服务之间的通信. 背景 随着企业越来越多地转向微服务,对构建这些微服务的低延迟和可扩展框架 ...
- 罗辑思维首席架构师:Go微服务改造实践
转自:http://www.infoq.com/cn/news/2018/05/luojisiwei 方圆 曾先后在 Cisco,新浪微博从事基础架构研发工作.十多年一直专注于后端技术的研发,在消息通 ...
随机推荐
- 【linux】常用命令集锦&持续更新...
滴:转载引用请注明哦[握爪]:https://www.cnblogs.com/zyrb/p/9709013.html 对深度学习训练及日常work中的常用linux命令进行整理. [一]screen ...
- Java发布webservice应用并发送SOAP请求调用
webservice框架有很多,比如axis.axis2.cxf.xFire等等,做服务端和做客户端都可行,个人感觉使用这些框架的好处是减少了对于接口信息的解析,最主要的是减少了对于传递于网络中XML ...
- unicorn与nginx通讯--[ruby unix socket]
[龍昌博客] http://www.xefan.com/archives/84146.html unicorn是如何与nginx通讯的——介绍ruby中的unix socket Ruby 应用服务典型 ...
- 虚拟云主机创建多个站点方法(.htaccess实现)
阿里的普通版虚拟云主机最多只能建一个站点,但可以绑定多个域名.如果我们想创建2个或3个主机怎么办呢?难道需要再另外购买一台主机? 其实我们可以通过.htaccess文件来定义相关域名绑定对应的网站目录 ...
- 【SQL学习笔记】一、select语句
SQL有别于其他的编程语言的一点在于首先处理的并不是写在第一行的语句(select),而是from字句. 为了更详细的了解select语句的每个部分,举例如下: 该语句返回的结果是下订单超过4次的女顾 ...
- 关于vue中如何配置echarts以及使用方法
ECharts,一个使用 JavaScript 实现的开源可视化库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等) ...
- 前端node.js npm i 报错Unexpected end of JSON input while parsing near
清缓存 npm cache clean --force 重新安装 npm install
- L1-Day14
今天是周日,不用交作业,但是需要把这一周的知识点复习总结 做个思维导图吧
- L1-Day13
1.Being late is an unforgivable sin here.[我的翻译]在北京,迟到是不可饶恕的罪名.[标准答案]在这里迟到是不可原谅的.[对比分析]对自己的也是醉醉的了,Bei ...
- HTML5+CSS3-学习总结
这是第三次学标签和样式了,虽然距离上次差不多2年.可学过的东西依旧还在. 体会 1. 相对于前端技术,基础还是很重要的. 2. 虽然很繁多.并不是杂乱无章的. 3. HTML5在新增的几个标签, ...