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,新浪微博从事基础架构研发工作.十多年一直专注于后端技术的研发,在消息通 ...
随机推荐
- 使用vcastr22.swf做flash版网页视频播放器
flash的安装设置参考 Flash设置(各种版本浏览器包括低版本IE) 百度搜索下载vcastr22.swf文件 然后使用方式很简单,浏览器安装flash相关插件就能看了 视频路径主要在这里,视频 ...
- Synchronized与ReentrantLock区别总结(简单粗暴,一目了然)
这篇文章是关于这两个同步锁的简单总结比较,关于底层源码实现原理没有过多涉及,后面会有关于这两个同步锁的底层原理篇幅去介绍. 相似点:这两种同步方式有很多相似之处,它们都是加锁方式同步,而且都是阻塞式的 ...
- I2C(三) linux3.4(内核分析)
目录 I2C(三) linux3.4(内核分析) (一)总线流程 bus.probe match i2c_device_probe (二)client注册 方式(一)静态加载 方式(二)指定设备 方式 ...
- 机器学习中模型泛化能力和过拟合现象(overfitting)的矛盾、以及其主要缓解方法正则化技术原理初探
1. 偏差与方差 - 机器学习算法泛化性能分析 在一个项目中,我们通过设计和训练得到了一个model,该model的泛化可能很好,也可能不尽如人意,其背后的决定因素是什么呢?或者说我们可以从哪些方面去 ...
- SNMP mib文件说明
MIB file的开始和结束 所有的MIB file的都以DEFINITIONS ::= BEGIN关键字开始,以END结束.我们所有添加的节点均应在此之间. XXX-TEST-MIB DEFINIT ...
- MySQL学习笔记(七)使用AutoMySQLBackup工具自动备份MySQL数据库
1.下载 wget https://nchc.dl.sourceforge.net/project/automysqlbackup/AutoMySQLBackup/AutoMySQLBackup%20 ...
- 记一次线上Java程序导致服务器CPU占用率过高的问题排除过程
博文转至:http://www.jianshu.com/p/3667157d63bb,转本博文的目的就是需要的时候以防忘记 1.故障现象 客服同事反馈平台系统运行缓慢,网页卡顿严重,多次重启系统后问题 ...
- linux_systemctl介绍
声明:本文转载自:systemd (中文简体) systemd 是 Linux 下的一款系统和服务管理器,兼容 SysV 和 LSB 的启动脚本.systemd 的特性有:支持并行化任务:同一时候採用 ...
- CORS跨域 Ajax headers 问题
今天我们遇到了一个CORS跨域的问题Ajax如下 var url = "http://localhost:11980/api/Demo/GetString"; //api地址 $. ...
- python魔法方法之构造和析构
python的类实例化的时候会默认执行该类的构造方法_init_ class Rectangle: def __init__(self,x,y): self.x=x self.y=y def getA ...