spider RPC性能測試報告

来源:http://www.cnblogs.com/zhjh256/archive/2016/11/19/6080802.html
-Advertisement-
Play Games

測試環境部署結構 測試用例 public @ResponseBody String t1001(Model model,HttpServletRequest request){ PlatformReq req = new PlatformReq().createDemo(); req.setComp ...


測試環境部署結構

spide_performance_network

測試用例

類 別 說明
請求報文 194位元組({“systemId”:”PL”,”appVersion”:”qq.qq.qq”,”companyId”:”12″,”sourceIp”:”DESKTOP-NDOHT79″,”destIp”:”DESKTOP-NDOHT79″,”spiderOpts”:{},”companyName”:”機構1″,”createDate”:”20160101″,”companyType”:1})
響應報文 178位元組({“lists”:[{“nodeId”:100001,”nodeName”:”機構100001″,”companyId”:”1200″,”createDate”:”20160101″},{“nodeId”:100001,”nodeName”:”機構100001″,”companyId”:”1200″,”createDate”:”20160101″}]})。
客戶端用例     @RequestMapping(value=”/1001.html”)

 

public @ResponseBody String t1001(Model model,HttpServletRequest request){

PlatformReq req = new PlatformReq().createDemo();

req.setCompanyId(“12”);

req.setSystemId(“PL”);

// 之所以每次HTTP請求調用5次spider請求,是因為一開始用單次跑,客戶端很快就到cpu 100%,以至於spider NB一直壓不到CPU 100%,故調整。

platformService.doQuery(req);

platformService.doQuery(req);

platformService.doQuery(req);

platformService.doQuery(req);

platformService.doQuery(req);

return JsonUtils.toJson(platformService.doQuery(req));

}

 

服務端用例 @Service

 

public class PlatformServiceImpl implements PlatformService {

     public PlatformQuery doQuery(PlatformReq req) {

         //System.out.println(“收到spider請求: ” + req.toString());

         PlatformQuery query = new PlatformQuery();

         return query.createDemo();

    }

}

併發數 200

 

測試結果

項目名稱 結果
客戶端運行次數 約1500萬
Spider調用次數 約7500萬
平均響應時間 90毫秒
客戶端QPS 2199次/秒
Spider NB/NP QPS 約11000次/秒(2199*5=10995)(就NB伺服器本身而言,因為用的是vmware且伺服器配置低下,所以軟中斷所占CPU比較高)
Spider客戶端負載 95%~100%
Spider NB負載 90%-95%
Spider NP負載 60%左右
失敗率 <0.01%

註:在阿裡雲ECS 8C/8GB上測試時,TPS 大約在18000後,受制於阿裡雲ECS伺服器單隊列網卡環境軟中斷過高問題,導致cpu在50%之後便無法再上去,具體可參考http://www.cnblogs.com/zhjh256/p/6020609.html。

原始數據

spider_jmeter_loader

spider_jmeter_result

spider_nb_loader

spider_client_loader

spider_np_loader

 


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

-Advertisement-
Play Games
更多相關文章
  • SQL跟蹤如下: 建議加一個 go 語句解決問題,如下圖 ...
  • 本文實例展示了DevExpress實現為TextEdit設置水印文字的方法,是一個很實用的技巧。分享給大家供大家參考。 轉自 http://blog.csdn.net/yh0503/article/details/51487726 關鍵代碼如下: 1 public static void SetWa ...
  • ASP.NET MVC 基礎入門 http://www.cnblogs.com/liunlls/p/aspnetmvc_gettingstarted.html 設置預設啟動頁面 設置重定向配置(沒有登錄的匿名用戶將重定向到配置的地址) 設置控制器過濾器; 特性也可以只設置方法;下麵的代碼中,如果用戶 ...
  • 這個配置節甚是簡單,在MSDN中的介紹也甚是簡單:為 ASP.NET 應用程式配置頁的視圖狀態設置。 historySize的作用是設置要存儲在頁歷史記錄中的項數。 但是這根本是看不明白他是幹嘛的,百度上一大串都是單純說說配置節的意思,根本沒再進一步闡述他的作用,我就不信其他人都懂了。還好有谷歌。看 ...
  • 概述 該示例(TODO MVP)是後續各種示例演變的基礎,它主要演示了在不帶架構性框架的情況下實現M V P模式。其採用手動依賴註入的方式來提供本地數據源和遠程數據源倉庫。非同步任務通過回調處理。 註意:MVP中View的概念是有所不同的: android.view.View類我們叫它 "Androi ...
  • Google-Guice入門介紹(較為清晰的說明瞭流程):http://blog.csdn.net/derekjiang/article/details/7231490 使用Guice,需要添加第三方的包(guice-3.0.jar和javax.inject.jar) 鏈接:http://pan.b ...
  • CSDN最近改規則了,改的越來越不順心,推薦到首頁的文章質量不再受限制,一下子降低了首頁的文章質量。這個消息是在官方博客QQ群裡面看到的,來源很可靠,只是CSDN還沒有發公告而已,又或者也許不必要再發公告了。我覺得這種做法是既損害博客作者的事情,又損害讀者的事情,具體詳情,請參考我的CSDN博文,h ...
  • 一、PHP 標記 當解析一個文件時,PHP 會尋找 起始 和 結束標記 ,也就是``,在標記外的部分會被解析器忽略。 註意 開始標記後面必須跟上一個空白符,否則就會出錯。 二、從 HTML 中分離 凡是在PHP開始和結束標記之外的內容,都會被PHP解析器忽略。例外是使用控制語句時: 三、指令符分隔 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...