偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

性能測試之MQTT最大設備連接數(shù)

移動開發(fā)
MQTT協(xié)議是一種消息隊列傳輸協(xié)議,采用訂閱、發(fā)布機制,訂閱者只接受自己已經訂閱的數(shù)據(jù),非訂閱數(shù)據(jù)則不接受,既保證了必要的數(shù)據(jù)交換,又避免了無效數(shù)據(jù)造成的存儲與處理。因此在工業(yè)物聯(lián)網中得到廣泛的應用。

Part 01

MQTT協(xié)議

MQTT協(xié)議是物聯(lián)網平臺的最通用協(xié)議之一,也是OneNET平臺的首要設備接入協(xié)議。物聯(lián)網平臺必須海量設備接入,但MQTT接入服務究竟能同時支持多少設備同時在線呢?了解這個指標能更好地為平臺的運維和運營提供科學的依據(jù)。

可是,如何快速簡便地測試最大在線量指標呢?如何選取工具和制作腳本呢?

測試性能我們首先想到的是常用的Jmeter和Locust等性能測試工具。但是這些工具的優(yōu)勢在測試服務的并發(fā)和吞吐量,并不適合當前的測試場景。

然后能想到的是利用第三方Jar包或者三方庫實現(xiàn)的協(xié)議庫,采用多線程啟動設備。但是壓力機線程啟動有限,對動則支持幾十萬上百萬設備接入量的服務簡直就是杯水車薪,需要多少壓力機難以估量。

再次能想到的是Select方法批量管理設備的Socket連接。問題又出現(xiàn)了,Select管理的異步IO也是有極限的,此方法最終還是放棄。

Part 02

測試方法 

經過前面的分析、實踐最終方法確定,采用異步IO的方式批量模擬設備連接服務器,按照一定的頻率上報注冊報文,不斷遍歷設備Socket接收的緩存數(shù)據(jù),解析服務消息來判斷設備是否連接成功,并通過周期性上報心跳來保持設備持續(xù)在線。實現(xiàn)細節(jié)如下:

(1)實現(xiàn)基礎設備類:封裝部分MQTT協(xié)議報文方法,其中包括設備注冊、訂閱、發(fā)布、心跳等。

圖片

MQTT注冊報文封裝示例(Java)

(2)實現(xiàn)設備類:主要記錄設備注冊狀態(tài)、訂閱狀態(tài)、?;铋g隔,最重要的服務消息的解析和響應方法,以及設備連接服務器的非阻塞Socket(Java中的SocketChanel)

圖片

服務消息解析代碼示例(Java)

(3)實現(xiàn)程序主體類:管理批量設備,控制設備注冊頻率,設備何時上報數(shù)據(jù)、監(jiān)聽服務下發(fā)數(shù)據(jù),統(tǒng)計設備連接數(shù),持續(xù)上報心跳,保持設備在線等。具體實現(xiàn)邏輯如下:

  • 批量初始化設備列表;
  • 同時啟動一下三個線程;
  • 啟動設備注冊線程,初始化設備與服務連接并上行注冊報文,可根據(jù)設置,指定當前可同時注冊的設備數(shù),所有設備注冊完成后自動退出;
  • 啟動連接統(tǒng)計線程,周期性統(tǒng)計設備連接成功個數(shù)、訂閱成功個數(shù)、連接失敗設備等數(shù)據(jù);
  • 啟動設備Socket遍歷線程,持續(xù)輪詢每個Socket的接收數(shù)據(jù),對接收到的數(shù)據(jù)處理和響應,每輪遍歷完畢對需要對未長時間未上報心跳的設備上行心跳報文,以達到設備?;畹哪康?。

圖片

程序主題類接收線程邏輯代碼片段(Java)

完成程序代碼后,測試工具制作完成。

此工具已實際用于項目性能測試中,可將壓力機全部可用端口用于最大設備在線量的測試中,實際在Linux虛擬機中幾分鐘內完成50000+設備注冊,并保持設備長時間持續(xù)在線。

此工具能最大限度利用壓力機端口資源,提升測試執(zhí)行效率,對于在線量較大的服務,只需要在更多的壓力機上運行此工具即可。

責任編輯:龐桂玉 來源: 移動Labs
相關推薦

2012-05-04 08:03:21

Windows

2011-07-22 16:26:50

SDE最大連接數(shù)

2011-04-07 14:17:56

2010-05-17 11:38:15

2021-07-02 10:42:55

MySQL連接數(shù)管理

2010-04-20 16:38:44

Oracle最大連接數(shù)

2012-03-28 14:46:57

Windows服務器終端連接數(shù)

2010-10-11 13:29:53

MYSQL最大連接數(shù)

2010-10-14 15:00:25

MySQL服務器

2014-04-03 14:05:04

CactiCacti監(jiān)控

2010-05-10 16:40:18

終端服務器超出了最大允

2010-05-19 16:10:49

MySQL連接數(shù)

2010-11-08 14:40:46

SQL Server連

2011-05-12 14:50:03

2010-05-24 11:00:18

2010-05-31 18:41:10

MySQL連接數(shù)

2010-05-31 19:42:00

Ubuntu

2010-04-23 16:26:30

Oracle并發(fā)連接數(shù)

2010-06-13 17:29:10

MySQL連接數(shù)

2010-05-31 19:26:02

Ubuntu mrtg
點贊
收藏

51CTO技術棧公眾號