求个 django+nginx+gunicorn 配置优化

2015-04-05 12:53:27 +08:00
 n37r06u3
已有配置如下

https://gist.github.com/n37r06u3/86f2fc9bd792217d4c2e/edit


siege 测试有fail

Transactions: 9796 hits
Availability: 97.96 %
Elapsed time: 52.50 secs
Data transferred: 1.22 MB
Response time: 0.80 secs
Transaction rate: 186.59 trans/sec
Throughput: 0.02 MB/sec
Concurrency: 148.41
Successful transactions: 9796
Failed transactions: 204
Longest transaction: 19.64
Shortest transaction: 0.03

FILE: /usr/local/var/siege.log
You can disable this annoying message by editing
the .siegerc file in your home directory; change
the directive 'show-logfile' to false.
$ siege -c 1000 -r 10 -u http://xxx.com/
2309 次点击
所在节点    Python
2 条回复
msg7086
2015-04-05 16:47:14 +08:00
每秒186次不少了吧,实际运行的时候会有这个级别的并发量吗。
另外建议先看一下是哪边拒绝了请求吧。目测是gunicorn的问题?
ryd994
2015-04-05 17:55:10 +08:00
workers = multiprocessing.cpu_count()*2
worker_processes 48;
这两条不合适吧。nginx的worker process只要cpu数量就足够了,考虑后端的话甚至更少然后作cpu affinity
tcp_tw_recycle tcp_tw_reuse 慎用
Longest transaction 19秒,估计是后面顶不住了
fail的话看看error log吧

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/181683

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX