我有一个同步的单进程web应用程序,CPU绑定为2,200 QPS。当我进行多次处理时,QPS只显示有限的增幅:
top显示CPU为100%top以60%的速度显示每个进程top以30%的速度显示每个进程我不明白这些数字。为什么两个进程不将QPS乘以2?四个过程4?
实现细节
Falcon,它是文档中的示例的拷贝粘贴gunicorn后面。下面是用于:的命令行gunicorn things:appgunicorn things:app -w 2gunicorn things:app -w 4
locust来执行负载测试和测量产生的QPS。配置:一个主人和五个奴隶。每个GET请求之间的等待时间:0 ms。localhost上。测试机有16个内核,因此web应用程序的每个进程和负载测试的每个进程都使用自己的核心。更多的结果
正如dano所建议的,我在GET处理程序中插入了一个time.sleep。以下是产生的QPS:

发布于 2014-08-14 15:01:18
看起来,locust向您的服务器发送查询的速度受到了限制(也可能限制了gunicorn将请求分发给工作人员的能力)。由于没有网络延迟,而且服务器几乎不工作(因此响应时间非常快),您就可以像蝗虫发送查询一样快速地进行响应。
古尼科恩博士强烈建议在NGINX之后运行它。。也许试一试,看看这对性能有什么影响。
https://stackoverflow.com/questions/25310183
复制相似问题