硬肝一次 Python 微服务是一种什么体验?

本文转载自微信公众号「AirPython」,作者星安果。转载本文请联系AirPython公众号。

为桓仁等地区用户提供了全套网页设计制作服务,及桓仁网站建设行业解决方案。主营业务为成都网站制作、网站设计、外贸网站建设、桓仁网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

1. 前言

大家好,我是安果!

考虑到 Python 性能及效率性,Python Web 端一直不温不火,JAVA 和 Golang 的微服务生态一直很繁荣,也被广泛用于企业级应用开发当中

本篇文章将介绍一款 Python 微服务框架:「 Nameko 」

2. Nameko 介绍

Nameko 是一款小巧、简洁的、异步通信方式的微服务架构

它采用 RabbitMQ 消息队列作为消息中间件,基于发布者、订阅者模式

其中,消费者与生产者基于 RPC 进行通讯

项目地址:https://github.com/nameko/nameko

3. 实战一下

下面以 Flask 为例聊聊搭建 Python 微服务的步骤

3-1 安装 RabbitMQ 及启动

这里推荐利用 Docker 安装 RabbitMQ,以 Centos 为例

 
 
 
  1. # 1、下载某个版本的RabbitMQ的镜像 
  2. # MQ版本号:3.9.5 
  3. docker pull rabbitmq:3.9.5-management 
  4.  
  5. # 2、查看镜像 
  6. docker images 
  7.  
  8. # 3、启动MQ容器 
  9. # p:指定应用端口及Web控制台端口 
  10. # hostname:主机名 
  11. # e:环境变量 
  12. # RABBITMQ_DEFAULT_VHOST:虚拟机名称 
  13. # RABBITMQ_DEFAULT_USER:用户名 
  14. # RABBITMQ_DEFAULT_PASS:密码 
  15. # 3e83da0dc938:MQ镜像ID 
  16. docker run -d --name rabbitmq3.9.5 -p 5672:5672 -p 15672:15672 -v `pwd`/data:/var/lib/rabbitmq --hostname myRabbit -e RABBITMQ_DEFAULT_VHOST=my_vhost  -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin 3e83da0dc938 

需要注意的是,启动 MQ 容器时,利用 -p 指定了两个端口

  • 5672

应用访问端口

  • 15672

控制台 Web 访问端口号

然后,开放防火墙的 5672、15672 端口号

PS:如果是云服务器,需要另外配置安全组

最后,在浏览器中通过下面的连接进入到 MQ 后台 Web 管理页面

地址:http://ip地址:15672

3-2 安装依赖包

使用 pip 命令在虚拟环境下安装 nameko、flask 依赖包

 
 
 
  1. # 安装依赖包 
  2. # nameko 
  3. pip3 install nameko 
  4.  
  5. # flask 
  6. pip3 install flask 

3-3 创建服务生产者 Producer

自定一个类,使用 name 属性定义服务的名称为「 generate_service 」

然后使用装饰器「 rpc 」注册服务中具体的方法

 
 
 
  1. # producer_service.py 
  2.  
  3. from nameko.rpc import rpc 
  4.  
  5. class GenerateService(object): 
  6.     # 定义微服务名称 
  7.     name = "generate_service" 
  8.  
  9.     @rpc 
  10.     def hello_world(self, msg): 
  11.         print('hello,i am been called by customer(消费者),返回消息:{}'.format(msg)) 
  12.  
  13.         # 返回结果 
  14.         return "Hello World!I Am a msg from producer!" 

3-4 发布注册服务

使用 nameko 命令在终端将目标文件中的服务注册到 MQ 中

 
 
 
  1. # 注册服务 
  2. # producer_service:目标文件 
  3. # admin:admin:MQ用户名及密码 
  4. # ip地址:5672:MQ服务器ip地址及应用端口号 
  5. # my_vhost:虚拟机名 
  6. nameko run producer_service --broker amqp://admin:admin@ip地址:5672/my_vhost 

其中,my_vhost 对应 MQ 容器启动时配置的虚拟机名

3-5 Flask 定义 API 及消费者调用服务

为了演示方便,这里使用 Flask 编写一个简单的 API

首先,定义 MQ 连接信息

然后,编写一个 API 接口,请求方式为 GET

最后,使用 nameko 中的「 ClusterRpcProxy 」拿到消费者对象去调用服务中的具体方法

 
 
 
  1. from flask import Flask 
  2. from nameko.standalone.rpc import ClusterRpcProxy 
  3.  
  4. app = Flask(__name__) 
  5.  
  6. # MQ配置 
  7. config_mq = {'AMQP_URI': "amqp://admin:admin@ip地址:5672/my_vhost"} 
  8.  
  9. @app.route('/hello_world', methods=['GET']) 
  10. def call_service(): 
  11.     with ClusterRpcProxy(config_mq) as rpc: 
  12.         # 消费者调用微服务(生产者),获取服务(生产者)的返回值 
  13.         result = rpc.generate_service.hello_world(msg="xag msg") 
  14.  
  15.         # 返回结果 
  16.         return result, 200 
  17.  
  18. app.run(debug=True) 

3-6 测试一下

使用 Postman 调用上面的 API 接口,就能完成消费者调用生成者服务中的方法,拿到返回结果的完整流程

 
 
 
  1. # 调用API接口 
  2. http://127.0.0.1:5000/hello_world 
  3. Method:GET 

4. 最后

上面以 Flask 为例讲解了微服务的搭建的完整流程

如果是其他 Web 框架( 比如 Django、FastAPI 等 )集成微服务流程是类似的,只需要修改生成 API 部分的逻辑即可,更多进阶内容大家可以参考官方文档

官方文档:https://nameko.readthedocs.io/en/stable/

分享文章:硬肝一次 Python 微服务是一种什么体验?
分享地址:http://www.csdahua.cn/qtweb/news48/273798.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网