在桌面创建一个名为django_test的项目:
django-admin startproject django_test
然后使用cd命令进入django_test文件夹内,使用开发者服务器运行项目:
python manage.py runserver
启动后,使用浏览器访问http://127.0.0.1:8000/,效果如下:
本次使用ApacheBench压力测试工具,用于测试http服务器请求的性能情况(下载链接,提取码:768b )。
解压后进入Apache24中的bin文件夹内,运行下述命令:
./ab.exe -n100 -c50 http://127.0.0.1:8000/
上述命令表示模拟50个并发,每个并发发送100个访问请求。
对于django的开发者服务器来说,测试效果如下:
Requests per second: 26.42 [#/sec] (mean) Time per request: 1892.848 [ms] (mean) Time per request: 37.857 [ms] (mean, across all concurrent requests) Transfer rate: 281.54 [Kbytes/sec] received
其中,每秒可以处理的请求数为26.42,这并不是一个很高的值,下面使用一个生产级服务器用于部署django。
uvicorn 是基于 uvloop 和 httptools 构建的非常快速的 ASGI 服务器,下面使用它来部署django程序。
首先安装uvicorn
pip install uvicorn
然后使用下面的命令启动django:
python -m uvicorn django_test.asgi:application
然后再按照第2部分内容使用压力测试工具对其进行压力测试,效果如下:
Requests per second: 143.65 [#/sec] (mean) Time per request: 348.058 [ms] (mean) Time per request: 6.961 [ms] (mean, across all concurrent requests)
可以看到,每秒可以处理的请求数为143.65,比使用开发者服务器快了将近6倍。
前面使用uvicorn将django项目进行了生产级部署,显著提高了访问效率。但是这种部署只使用了一个进程,在最终部署时可以根据服务器核数部署多进程服务,命令如下:
python -m uvicorn django_test.asgi:application --workers 2
这里的参数–workers表示进程数,上述命令使用2个进程进行服务。
再按照第2部分内容使用压力测试工具对其进行压力测试,效果如下:
Requests per second: 214.66 [#/sec] (mean) Time per request: 232.923 [ms] (mean) Time per request: 4.658 [ms] (mean, across all concurrent requests)
可以看到,每秒可以处理的请求数为214.66,比单进程快了很多。