snaic和tornado的簡單性能測試

来源:https://www.cnblogs.com/MikeZhang/archive/2019/11/02/snaic_vs_tornado_20191102.html
-Advertisement-
Play Games

操作系統 : CentOS7.3.1611_x64 Python 版本 : 3.6.8 tornado版本:6.0.2 snaic版本:19.9.0 CPU : Intel(R) Core(TM) i5-2320 CPU @ 3.00GHz 4核 之前一直使用tornado作為http相關pytho ...


操作系統 : CentOS7.3.1611_x64

Python 版本 : 3.6.8

tornado版本:6.0.2

snaic版本:19.9.0

CPU : Intel(R) Core(TM) i5-2320 CPU @ 3.00GHz 4核

之前一直使用tornado作為http相關python程式的框架,最近查資料發現新出的snaic性能很高,這裡在同樣硬體條件下使用ab進行簡單的壓測。

準備工作

安裝apache ab工具:

yum -y install httpd-tools

壓測命令:

ab -c 30 -n 100000 http://127.0.0.1:9093/

參數說明:

-c :模擬併發數

-n : 總請求數

對比測試

使用tornado實現的簡單http伺服器代碼:

https://github.com/mike-zhang/pyExamples/blob/master/httpRelate/httpServer/tornadoTest1.py

使用snaic實現的簡單http伺服器代碼:

https://github.com/mike-zhang/pyExamples/blob/master/httpRelate/httpServer/snaicTest1.py

tornado測試結果:

Server Software:        TornadoServer/6.0.2
Server Hostname:        127.0.0.1
Server Port:            9093

Document Path:          /
Document Length:        12 bytes

Concurrency Level:      30
Time taken for tests:   82.282 seconds
Complete requests:      100000
Failed requests:        0
Write errors:           0
Total transferred:      20700000 bytes
HTML transferred:       1200000 bytes
Requests per second:    1215.33 [#/sec] (mean)
Time per request:       24.685 [ms] (mean)
Time per request:       0.823 [ms] (mean, across all concurrent requests)
Transfer rate:          245.68 [Kbytes/sec] received

Connection Times (ms)
                          min  mean[+/-sd] median   max
Connect:        0    0   0.2      0       8
Processing:     1   25  10.3     25      74
Waiting:        1   24  10.3     25      74
Total:          1   25  10.3     25      74

Percentage of the requests served within a certain time (ms)
  50%     25
  66%     30
  75%     33
  80%     34
  90%     37
  95%     39
  98%     41
  99%     42
 100%     74 (longest request)

snaic測試結果:

Server Software:
Server Hostname:        127.0.0.1
Server Port:            9093

Document Path:          /
Document Length:        12 bytes

Concurrency Level:      30
Time taken for tests:   20.164 seconds
Complete requests:      100000
Failed requests:        0
Write errors:           0
Total transferred:      11100000 bytes
HTML transferred:       1200000 bytes
Requests per second:    4959.29 [#/sec] (mean)
Time per request:       6.049 [ms] (mean)
Time per request:       0.202 [ms] (mean, across all concurrent requests)
Transfer rate:          537.58 [Kbytes/sec] received

Connection Times (ms)
                          min  mean[+/-sd] median   max
Connect:        0    2   0.5      2      11
Processing:     1    4   1.5      4      38
Waiting:        0    4   1.4      3      37
Total:          1    6   1.5      6      41

Percentage of the requests served within a certain time (ms)
  50%      6
  66%      6
  75%      7
  80%      7
  90%      7
  95%      8
  98%      9
  99%     10
 100%     41 (longest request)

從測試結果可以看到,開啟兩個進程情況下:

tornado的cps是 1215.33 ,平均響應時間是 24.685 ms

snaic的cps是 4959.29 ,平均響應時間是 6.049 ms

修改併發數後的測試數據如下:

 

 測試結果對比如下:

 

從測試數據來看,snaic的cps比tornado高,平均響應時間方面,snaic也比tornado短。

本文github地址:

https://github.com/mike-zhang/mikeBlogEssays/blob/master/2019/20191102_snaic和tornado的簡單性能測試.rst

歡迎補充


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 基礎類型 介紹 為了讓程式有價值,我們需要能夠處理最簡單的數據單元:數字,字元串,結構體,布爾值等。 TypeScript支持與JavaScript幾乎相同的數據類型,此外還提供了實用的枚舉類型方便我們使用。 布爾值 最基本的數據類型就是簡單的true/false值,在JavaScript和Type ...
  • 本文將為您描述如何解決 eharts.js報錯 Uncaught TypeError: Cannot read property 'getAttribute' of null 的問題 根據報錯信息查找原因發現是因為 實例化 echarts 的元素不存在(未找到指定的元素),查看官方文檔發現: 基於準 ...
  • 前端 JS 獲取 Image 圖像 寬高 尺寸 簡介 項目中用到獲取圖片的原始尺寸,然後適配寬高;網上的大部分前端解決方案,都是new Image()後,在onload事件中獲取image的尺寸。 在圖片數量較多的時候,這樣的獲取效率實在是低下。所有就有了這篇文章。通過直接讀取解析文件的位元組碼來獲取 ...
  • Web前端要如何學?這是很多新手都會問的問題,究竟web前端開發要學什麼內容?學習起來難不難? ...
  • 我只安裝了webpack,沒有安裝webpack cli,第一次輸入webpack打包時,提示 輸入yes後報錯 解決辦法:輸入命令npm install webpack cli g全局安裝一下webpack cli 再次運行webpack命令打包,出現新錯誤 解決辦法:根據錯誤提示信息,打開nod ...
  • 1 #需求 遍歷文件夾中所有的子文件夾及子文件--用遞歸實現 2 3 '''''' 4 ''' 5 偽代碼 6 1、遍歷根目錄--listdir for 7 得到第一級子文件夾(不包含子文件夾的子文件)和文件 8 2、判斷是文件還是文件夾 9 如果是文件,就直接列印文件名 10 如果是文件夾(全路徑... ...
  • 2019-11-02-23:25:26 目錄 1.泛型的概念: 2.泛型的定義和使用: 2.1定義和使用含有泛型的類: 2.2定義和使用含有泛型的方法: 2.3定義和使用含有泛型的介面: 泛型的概念: 泛型是一種未知的數據類型,當我門不知道使用什麼數據類型的時候,可以使用泛型,泛型也可以看成是一個變 ...
  • 1、表達式:關係表達式或邏輯表達式; 2、表達式的運算結果應該是“真”或者“假”; 真:執行該語句; 假:跳過該語句,執行下一條語句; 3、“語句”可以是單語句也可以是複合語句; 4、else if 可以有多條,沒有上限; 5、if 和 else if都需要判斷表達式真假,else則不需要,else ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...