python性能压测核心是模拟真实并发、监控qps/响应时间/错误率/资源占用并分层定位瓶颈;首选locust工具,支持脚本化场景设计、分布式压测及web界面控制,需结合服务端psutil/prometheus监控与数据库慢查分析,按网络→应用→依赖→系统顺序排查。

Python项目做性能压测,核心是模拟真实并发请求、监控关键指标(如QPS、响应时间、错误率、资源占用),并定位瓶颈。不依赖复杂工具,用好开源方案+合理设计场景,就能快速验证服务承载能力。
选对压测工具:Locust 是 Python 项目的首选
Locust 完全用 Python 编写,脚本即代码,灵活定义用户行为、动态调整并发、支持分布式压测,比 JMeter 更贴合 Python 开发者习惯。
- 安装简单:pip install locust
- 写一个 locustfile.py 就能启动压测,例如模拟 HTTP 接口调用:
from locust import HttpUser, task, between
class ApiUser(HttpUser):
wait_time = between(1, 3)
@task
def get_items(self):
self.client.get("/api/items")
- 启动命令:locust -f locustfile.py --host https://your-api.com,打开 Web 界面设置用户数和 spawn rate
设计真实压测场景:别只跑单接口
线上慢往往不是某个接口慢,而是多步骤组合、带状态、有数据依赖的链路慢。压测要贴近实际用户行为。
本文档主要讲述的是maven使用方法;Maven是基于项目对象模型的(pom),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。Maven将你的注意力从昨夜基层转移到项目管理层。Maven项目已经能够知道 如何构建和捆绑代码,运行测试,生成文档并宿主项目网页。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
立即学习“Python免费学习笔记(深入)”;
- 用 TaskSet 或 @task(weight) 模拟不同操作比例(如 70% 查列表、20% 提交订单、10% 查详情)
- 加入登录态:在 on_start() 中调用登录接口,把 token 存到 self.client.cookies 或 headers
- 参数化请求:用 csv 文件 或随机生成 ID,避免缓存干扰或数据库主键冲突
监控不能只看响应时间:必须抓服务端指标
客户端看到的“平均响应时间 200ms”可能掩盖严重问题——比如 CPU 打满、数据库连接池耗尽、日志刷屏阻塞 I/O。
- Python 服务端加基础监控:psutil 实时采集 CPU、内存、线程数、网络连接数,通过 Prometheus + Grafana 可视化
- 数据库重点看:慢查询数量、连接等待时间、TPS/QPS、锁等待(MySQL 的 SHOW PROCESSLIST,PostgreSQL 的 pg_stat_activity)
- 应用层打点:用 logging 或 structlog 记录关键路径耗时,配合 trace_id 串联日志
分析瓶颈要分层排查:从外到内逐层缩圈
压测中发现问题后,按“网络 → 应用 → 依赖 → 系统”顺序排查,避免过早优化。
- 先确认是不是网络或 CDN 问题:用 curl -w "@format.txt" -o /dev/null -s URL 看 DNS、TCP、TLS、首字节时间
- 查 Python 进程是否 GIL 卡死:用 py-spy record -p PID -o profile.svg 生成火焰图
- 检查异步瓶颈:如果是 FastAPI/Starlette,确认 await 是否漏写、同步阻塞调用(如 time.sleep、requests.get)是否混入协程
- 验证数据库:把 SQL 单独拿出来用 EXPLAIN ANALYZE 看执行计划,注意索引缺失、全表扫描、临时表










