在Centos7.3下使用Siege對Django服務進行壓力測試

原文轉載自「劉悅的技術博客」v3u.cn/a_id_87python

Siege是linux下的一個web系統的壓力測試工具,支持多連接,支持get和post請求,能夠對web系統進行多併發下持續請求的壓力測試。今天咱們就使用Siege來對Django進行一次壓力測試,看看單臺Django服務到底能抗住多少的併發數。mysql

首先安裝Siegelinux

wget http://download.joedog.org/siege/siege-3.0.8.tar.gz
tar zxvf siege-3.0.8.tar.gz
cd siege-3.0.8
./configure
make
make install

驗證安裝結果:輸入siege -V 若是輸出了版本號就表明安裝沒問題
複製代碼

Siege命令經常使用參數golang

-c 200 指定併發數200
-r 5 指定測試的次數5
-f urls.txt 制定url的文件
-i internet系統,隨機發送url
-b 請求無需等待 delay=0
-t 5 持續測試5分鐘web

測試指標說明:sql

Transactions: 4 hits 完成4次處理
Availability: 100.00 % 成功率
Elapsed time: 1.19 secs 總共用時
Data transferred: 0.03MB 共數據傳輸:0.03MB
Response time: 0.13 secs 相應用時0.13秒,顯示網絡鏈接的速度
Transaction rate: 3.36 trans/sec平均每秒完成3.36次處理,表示服務器後臺處理的速度
Throughput: 0.03MB/sec 平均每秒傳送數據:0.03MB
Concurrency: 0.45 最高併發數 0.45
Successful transactions: 4成功處理次數
Failed transactions: 0 失敗處理次數
Longest transaction:0.25請求最長響應時間/每次傳輸所花最長時間
Shortest transaction:0.09請求最短響應時間/每次傳輸所花最短期緩存

主要參考指標是Transaction ratebash

測試背景:服務器

軟件:python3.7.2 Django2.0.4網絡

硬件 內存:1g cpu:1個1核 這個硬件配置有點慘,沒辦法了,由於沒錢買好的

業務場景:Django使用mysql進行普通的讀操做,沒有使用任何緩存

壓測命令:255個用戶併發訪問localhost:8000,持續時間爲1分鐘

siege -c255 -t60S -v -b 127.0.0.1:8000
複製代碼

首先使用runserver的起服務方式進行壓測:

python3 manage.py runserver 0.0.0.0:8000
複製代碼

能夠看到,這個有點悽慘,每秒後臺只能處理166的請求,失敗次數也有點高,更加說明了,runserver最好就是本地調試開發的時候用用就能夠了,在生產環境使用runserver無異於自殺,不過在一些測試服務器上,若是懶得搭建uwsgi或者gunicorn,可使用nohup配合runserver臨時用一下。

使用uwsgi來起服務,uwsgi做爲一款高性能的服務器,安裝方式請見:v3u.cn/a_id_72起8個worker

uwsgi --http :8000 --module mypro.wsgi --processes 8
複製代碼

能夠看到使用了uwsgi的提高仍是很可觀的,失敗次數也減小了一半左右

最後,咱們來試一試Gunicorn

Gunicorn是使用Python實現的WSGI服務器, 直接提供了http服務, 而且在woker上提供了多種選擇, gevent, eventlet這些都支持, 在多worker最大化裏用CPU的同時, 還可使用協程來提供併發支撐, 對於網絡IO密集的服務比較有利

安裝 gunicorn

pip3 install gunicorn
複製代碼

起4個worker,50個線程

gunicorn --env DJANGO_SETTINGS_MODULE=mypro.settings mypro.wsgi:application -w 4 -b 0.0.0.0:8000 -k gthread --threads 50
複製代碼

能夠看到性能上和uwsgi差不太多,可是失敗數比較多。以1g1核的服務器,併發閾值也就在200左右了。

綜上,單以性能論,Django的表現並不是很好,可是你不能忽略它的學習成本低,簡單而且容易上手的優點,魚與熊掌不能兼得,若是要求高性能,能夠試試tornado, 若是tornado依然沒法知足,能夠嘗試使用golang,畢竟golang是以高併發著稱的編譯語言,並且基於它的web框架也很容易上手,性能很可觀,例如Iris。

原文轉載自「劉悅的技術博客」 v3u.cn/a_id_87

相關文章
相關標籤/搜索