0

0

分析异步Python

DDD

DDD

发布时间:2025-02-01 08:16:26

|

931人浏览过

|

来源于dev.to

转载

介绍

应用程序分析是一个分析程序以确定其特征的过程:执行时间不同的代码零件和资源用法。

分析的主要阶段总是或多或少相同的:

    测量执行时间
  1. 。执行不同的代码零件需要多少时间?
  2. 分析内存使用
  3. 。程序的不同部分消耗了多少内存? 识别瓶颈
  4. 。代码的哪些部分减慢了程序或使用太多资源?
  5. > >性能优化
  6. 。采取措施根据获得的数据提高执行速度和资源利用效率。
  7. 有限数量的异步代码的特定瓶颈。 让我们将每种类型与代码示例匹配。
  8. >
-

异步python中的瓶颈的主要类型

阻止操作

import asyncio
import time

async def main():
    print('start')
    # blocking call
    time.sleep(3)  # this blocks the entire event loop
    print('end')

asyncio.run(main())

顺序调用异步任务

import asyncio
import aiohttp

async def fetch(session, url):
    async with session.get(url) as response:
        return await response.text()

async def main():
    urls = ["http://medium.com"] * 10
    async with aiohttp.clientsession() as session:
        # inefficient: sequential requests
        for url in urls:
            await fetch(session, url)

asyncio.run(main())

过度上下文切换

import asyncio

async def tiny_task():
    await asyncio.sleep(0.0001)

async def main():
    # excessive context switching due to many small tasks
    await asyncio.gather(*(tiny_task() for _ in range(100000)))

asyncio.run(main())

资源饥饿

import asyncio

async def long_running_task():
    await asyncio.sleep(10)
    print("long task executed")

async def quick_task():
 await asyncio.sleep(1)
    print("quick task executed")

async def main():
    await asyncio.gather(
        long_running_task(),
        quick_task()  # may be delayed excessively
    )

asyncio.run(main())

内存开销

import asyncio

async def large_data_task():
    data = "lorep ipsum" * 10**8  # large memory usage
    await asyncio.sleep(1)

async def main():
    tasks = [large_data_task() for _ in range(100)]  # high memory consumption
    await asyncio.gather(*tasks)

asyncio.run(main())

-

顺便说一句,探查者一般如何工作?

>单独的文章将专门用于详细的评论,因为现在我们可以将自己限制在基本分类中:

>确定性剖析师

。主要代表是内置的cprofile。该探测器计算每个函数的调用数量以及功能所花费的时间。问题在于,异步呼叫的等待时间没有考虑到。
  • 统计剖面。普通代表是鳞状,py-spy,yappi,pyinsprument,奥斯汀。这样的探索者以某种频率进行了该过程的“快照”,并应用了统计分析的方法来搜索瓶颈。

    -
  • 使用鳞片进行分析

    为什么要鳞?因为此工具允许分析cpu和内存,因此在github上具有10k 星星,并且该项目正在积极开发。 >让我们看看上面列表中每个“有问题”代码的scalene所说的。

    >
  • 我们将像这样运行斜角:

36277728875

阻止操作

>您可以立即看到问题线,并立即阻止呼叫 - python的2%,在系统呼叫中的98%的时间。

顺序调用异步任务

>这里有点复杂。您可以看到90%的时间用于系统调用,但是该行已更改 - 现在它是本身。最好是记住这种剖面输出的模式。

过度上下文切换

calling asynchronous tasks sequentially我们看到内存消耗如何在>中增长 - 任务的“拆分”太贪婪了。

> 资源饥饿

再次,系统与python的时间比不支持python操作。excessive context switching>

内存开销

在这里,斯卡琳为我们做了一切,并立即向我们展示了有问题的代码。>

-

resource starvation 结论

>应该注意的是,对于三种情况 - “

立即学习Python免费学习笔记(深入)”;

阻止操作

”,“

依次调用异步任务

>”和“memory overhead> resource starvation

”相同的图片 - 系统%>> python%。澄清原因实际上需要开发人员。

如果您知道瓶颈的主要类型,并且准备仔细阅读profiler输出,那么python并不是一项艰巨且相当令人愉快的任务。

p.s.

这篇文章最初是在我一年多以前发布的。

>

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

153

2023.12.20

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

765

2026.01.21

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

101

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

86

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

29

2025.12.30

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

109

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

16

2026.01.26

苹果官方查询网站 苹果手机正品激活查询入口
苹果官方查询网站 苹果手机正品激活查询入口

苹果官方查询网站主要通过 checkcoverage.apple.com/cn/zh/ 进行,可用于查询序列号(SN)对应的保修状态、激活日期及技术支持服务。此外,查找丢失设备请使用 iCloud.com/find,购买信息与物流可访问 Apple (中国大陆) 订单状态页面。

131

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号