nginx + uwsgi + django 优化和参数设置

发布时间:2020-08-16 22:52:27 作者:陈驰打算做一辈子IT
来源:ITPUB博客 阅读:544

最近用python写了一个web系统,用的框架是nginx + uwsgi + django + oracle。服务器用的是centos 7.

web API的吞吐量要求是200/s。

使用postman对单次web API调用进行测试,时间约0.5s

将吞吐量乘上每次调用的时间,计算得到总共所需的处理单元数:200 * 0.5 = 100 处理单元。

uwsgi的processes最好不要设置太大,建议设置成和cpu个数一样。我测试用的服务器4个cpu。

所以 设置 processes=4, 而 threads=处理单元数 / processes=25

用jmeter进行测试,由于 吞吐量要求是200/s,所以jmeter测试时的threads数要设置为200,或稍大于200.

以上是个人总结的经验。

如果吞吐量要求很大,或web API处理时间比较慢,按以上公式得到的threads会比较大,而且服务器的

tcp连接数都可能会超过centos的默认值,需要对应调整。

uwsgi的listen队列值要对应调大,系统内核参数 somaxconn也要跟着调大。

调整文件中的参数:/etc/sysctl.conf

net.core.somaxconn= 4000

系统能同时打开的文件数要调整, 调整文件中的参数

/etc/security/limits.conf

* soft nproc 80000

* hard nproc 80000

* soft nofile 80000

* hard nofile 80000

推荐阅读:
  1. 怎么在Django中使用Vue.js实现前后端分离
  2. Django1.7+JQuery+Ajax验证用户注册集成小例子

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

django nginx uwsgi

上一篇:擎天神Atlas,撑起智能计算风暴

下一篇:SSL压力测试工具THC-SSL-DOS

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》