要测试 http 应用的 QPS(每秒请求数)和并发性能,你可以使用 wrk、ab(Apache Benchmark)、或 hey 等工具。下面介绍如何使用这些工具来测试 Flask 应用的性能。
wrk 进行 QPS 和并发测试wrk 是一个现代的 HTTP 基准测试工具,支持高并发。你可以通过 Homebrew 安装它:
brew install wrkwrk 测试假设你的 Flask 应用运行在 http://localhost:8001,你可以通过以下命令测试并发请求和 QPS:
wrk -t12 -c400 -d30s http://localhost:8001解释参数: - -t12:使用 12 个线程。 - -c400:模拟 400 个并发连接。 - -d30s:测试持续时间为 30 秒。 - http://localhost:8001:测试的目标 URL。
wrk 将会在终端输出测试结果,包括每秒请求数、延迟时间等。
ab(Apache Benchmark)测试ab 是 Apache 自带的一个简单的基准测试工具,你可以使用它来测试 Flask 应用的 QPS 和并发。
ab在 macOS 上可以通过 Homebrew 安装 ab:
brew install httpd然后可以直接使用 ab 命令:
ab -n 10000 -c 100 http://localhost:8001/解释参数: - -n 10000:总共发送 10,000 个请求。 - -c 100:每次并发 100 个请求。 - http://localhost:8001/:测试的目标 URL。
这将输出类似于以下内容:
Requests per second: 500.23 [#/sec] (mean)
Time per request: 200.46 [ms] (mean)hey 进行性能测试hey 是一个轻量级的 HTTP 性能测试工具,类似于 ab,但更简单易用。
hey使用 Homebrew 安装 hey:
brew install heyhey 测试使用以下命令进行 QPS 和并发测试:
hey -n 10000 -c 100 http://localhost:8001解释参数: - -n 10000:总共发送 10,000 个请求。 - -c 100:每次并发 100 个请求。 - http://localhost:8001:测试的目标 URL。
如果你的 QPS 或并发表现不理想,可以通过调整 Gunicorn 的工作进程和线程数来优化性能:
-w 参数)和线程数(--threads 参数)。gunicorn -w 4 --threads 4 -b 0.0.0.0:8001 app:app这会使用 4 个进程,每个进程使用 4 个线程来处理请求。
wrk、ab 或 hey 测试 Flask 应用的 QPS 和并发性能。