gevent实现python并发api接口

2024-04-07 04:48

本文主要是介绍gevent实现python并发api接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

公司之前算法对外提供服务都是通过flask框架生成的api接口的形式,而最近项目中需要提高算法api接口的并发性能,通过分析flask对外api接口发现,该api接口是串行的方式,也即阻塞的形式进行数据处理的(前一条数据处理完成,才会进入下一条数据的处理)。因此,将flask提供api接口改为gevent,改用gevent后,算法接口在并发性能上提升效果明显,下面简要记录一下,做个笔记。

测试工具JMeter

本文采用jmeter测试工具对算法接口性能进行测试。JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。

JMeter的安装:https://blog.csdn.net/Jenny_He/article/details/88926605

利用JMeter测试基于flask接口和基于gevent接口的性能时,其线程组的设置如下图所示,设置100个线程(模拟100次接口调用), 准备时长(Ramp-Up)设置为1秒。

线程组各参数的含义可参考:https://blog.csdn.net/u012111923/article/details/80705141

算法接口参数设置如下图所示 

基于flask的api接口

测试代码如下

# -*- coding: utf-8 -*-
# @Time        : 2019/4/2 10:16
# @Author      : tianyunzqs
# @Description :import os
import sys
import logging as logger
import tracebackfrom flask import Flask, request, json
from flask_cors import CORSpackage_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.append(package_path)
from dev_v6.xj_common import text_extract_apiapp = Flask(__name__)
CORS(app)@app.route('/xj_hsyp_common', methods=['GET', 'POST'])
def api_xj_common():try:data = request.form['data']if data:logger.info("输入:")logger.info(str(data))result = {"success": "true", "result": text_extract_api(text=data)}else:result = {"success": "false", "result": "输入错误。"}logger.info("输出: ")logger.info(str(result))return json.dumps(result, ensure_ascii=False)except:logger.error(traceback.format_exc())return json.dumps({"success": "false", "result": "程序异常"}, ensure_ascii=False)if __name__ == '__main__':app.run(host='0.0.0.0', port=3009, threaded=True)

 jmeter测试产生的结果分析如下图所示

从上图可看出,基于flask的算法接口的吞吐量为1.3/sec,而且接口的处理方式阻塞型的 。

基于gevent的api接口

安装gevent

gevent是python的第三方库,提供了比较完善的对协程的支持。它用到Greenlet提供的,封装了libevent事件循环的高层同步API。它让开发者在不改变编程习惯的同时,用同步的方式写异步I/O的代码。

gevent的相关介绍:https://www.jianshu.com/p/861f29ac68e8

Windows安装

在线安装

pip install gevent

离线安装

从https://www.lfd.uci.edu/~gohlke/pythonlibs/下载以下whl文件,先安装gevent的几个依赖包(cffi、greenlet、pycparser),最后安装gevent,安装命令:

pip install *.whl

​Linux安装

在线安装

pip install gevent

离线安装

下载依赖包greenlet:

https://files.pythonhosted.org/packages/2e/65/27f35497cc0102a792390d056e793e064da95fc9eae45d75ae0ba49c0a0d/greenlet-0.4.15-cp35-cp35m-manylinux1_x86_64.whl

下载完成后运行:

pip install greenlet-0.4.15-cp35-cp35m-manylinux1_x86_64.whl

下载gevent:

https://files.pythonhosted.org/packages/95/d2/f2f454b00fde1608f6f4889c8cc3e12b5000f26cd5c3e11b5427c7781de9/gevent-1.4.0-cp35-cp35m-manylinux1_x86_64.whl

下载完成后运行:

pip install gevent-1.4.0-cp35-cp35m-manylinux1_x86_64.whl

 性能测试

测试代码:

# -*- coding: utf-8 -*-
# @Time        : 2019/4/2 10:16
# @Author      : tianyunzqs
# @Description :import os
import sys
import logging as logger
import traceback
import configparserfrom gevent import monkey
from gevent.pywsgi import WSGIServer
monkey.patch_all()
from flask import Flask, request, json
from flask_cors import CORSpackage_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.append(package_path)
from dev_v6.xj_common import text_extract_apiapp = Flask(__name__)
CORS(app)@app.route('/xj_hsyp_common', methods=['GET', 'POST'])
def api_xj_common():try:data = request.form['data']if data:logger.info("输入:")logger.info(str(data))result = {"success": "true", "result": text_extract_api(text=data)}else:result = {"success": "false", "result": "输入错误。"}logger.info("输出: ")logger.info(str(result))return json.dumps(result, ensure_ascii=False)except:logger.error(traceback.format_exc())return json.dumps({"success": "false", "result": "程序异常"}, ensure_ascii=False)if __name__ == '__main__':http_server = WSGIServer(('', 3009)), app)http_server.serve_forever()

 jmeter测试产生的结果分析如下图所示 

 

从上图可看出,接口的吞吐量提升到了2.9/sec,而且接口的处理方式非阻塞型的。

对比测试结果发现,使用gevent后接口的性能明显提升;而且接口由原来的串行方式变为并行方式,真正提高了接口的并发处理能力。

这篇关于gevent实现python并发api接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/881667

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指