Django的runserver部署和uwsgi部署对比

查了很多资料都说Django的runserver不适合生产环境部署,具体的原因并没有查到,目前可以得出的结论是runserver运行默认是多线程的可以支持一定量的并发,但是Django的官方并不建议这种方式。

对比下runserver和uwsgi部署的性能差异,实验环境:

1、虚拟机创建宿主机:virtualbox-2C-2G

2、在宿主机中使用docker进行部署

3、jemeter进行压测。

测试的服务直接返回结果(Hello, world. You're at the polls index.)。

测试的服务添加sleep(1)作为性能消耗假设。

测试uwsgi线程的概念和Django服务的线程之间的关系。

场景一、runserver和uwsgi分别启动1、2、3个线程对比,有多个请求来验证是否能同时为多个请求服务。

都是从第三个请求开始表现出多线程的特性?uwsgi和runserver都表现出这个特性,不知道是否和虚拟环境有关。

runserver

uwsgi

 1个线程

2个线程

3个线程

runserver的jmeter压力测试

10秒100个用户

10秒200个用户

cat /proc/线程pid/status

10秒500个用户

10秒1000个用户

 uwsgi 2C4T的情况下

在用uwsgi的时候,jmeter测试的时候keepalive的配置需要将客户端类型设置为java,才会生效,否则会有大量的error请求。这总情况在runserver中并没有出现,怀疑应该是长短连接的问题。实际测试发现如果使用长连接的话耗时会小于1秒,应该是统计的问题,后面的测试取消了keepalive的选项。

10秒100个用户

总共8个线程完全支持不了100的并发,好处是对宿主机的性能没有太大影响,保持8个线程。 

uwsgi 2C8T

 uwsgi 2C16T

 

uwsgi 2C32T

 uwsgi 2C64T

 uwsgi 4C32T

 

  uwsgi 2C64T 压测10秒200个用户

结论:uwsgi的线程数是固定的,性能和负载也是可以提前预估出来的,对服务器的冲击较小。针对生产环境也相对稳定。runserver的性能也没有想象中的那么差,从测试结果来看,针对某些简单的应用也是可以使用的。


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部