Locust,一款主打負(fù)載測試的軟件,為網(wǎng)站進(jìn)行數(shù)據(jù)的訪問測試服務(wù),幫助小伙伴一鍵了解自己的數(shù)據(jù),更好的維護(hù)自己的網(wǎng)站,還可以輕松測試自己的瀏覽,訪問等等數(shù)據(jù),為小伙伴提供更多的幫助!
Locust詳情
Locust是一個(gè)開源的負(fù)載測試工具,用Python代碼定義用戶行為,讓數(shù)百萬用戶同時(shí)在你的系統(tǒng)中蜂擁而至,主要為網(wǎng)站或者其他系統(tǒng)進(jìn)行負(fù)載測試,能測試出一個(gè)系統(tǒng)可以并發(fā)處理多少用戶。
Locust特色
①、不需要編寫笨重的UI或者臃腫的XML代碼,基于協(xié)程而不是回調(diào),腳本編寫簡單易讀;
②、有一個(gè)基于we簡潔的HTML+JS的UI用戶界面,可以實(shí)時(shí)顯示相關(guān)的測試結(jié)果;
③、支持分布式測試,用戶界面基于網(wǎng)絡(luò),因此具有跨平臺(tái)且易于擴(kuò)展的特點(diǎn);
④、所有繁瑣的I / O和協(xié)同程序都被委托給gevent,替代其他工具的局限性;
Locust初步使用
概念理解(翻譯):
1. 超級(jí)類是 locust 類,它的每一個(gè)實(shí)例代表了一個(gè)用戶, 守護(hù)程序會(huì)為每一個(gè)模擬用戶生成一個(gè)實(shí)例
2. httplocust 繼承了locust 類, 添加了可以發(fā)送http請求的功能
3. locust 有一個(gè)屬性(成員變量)是 task_set , 它可以定義用戶的行為, 就是訪問哪些URL, post還是get, 每個(gè)連接占總訪問量比是多少
這個(gè)task_set 是類TaskSet(或其子類)的一個(gè)實(shí)例, 上邊說的各種行為就是在這個(gè)類里邊定義的
4. locsut類:
屬性: min_wait/max_wait 模擬用戶有在上邊說的類中定義了好多任務(wù)/行為, 每個(gè)任務(wù)/行為間隔多久執(zhí)行一次, 單位是毫秒, 默認(rèn)1000, 也即隔一秒種后執(zhí)行下一個(gè)任務(wù)
屬性: weight 權(quán)重: 模擬時(shí), 同一段時(shí)間, 手機(jī)用戶的訪問量要比PC的訪問量大, 那么對(duì)應(yīng)的locust(或其子類)的weight值就大小不一
屬性: host 就是需要被壓測的網(wǎng)站的域名(或域名前綴), 如果啟動(dòng)服務(wù)時(shí)沒有通過參數(shù)-host來指定域名, 那么就用使用該host屬性指定的值
TaskSet類:
1. 推薦的是, 在taskset類(或子類)中通過在行為(回調(diào)函數(shù))前加@task(weight)描述符來指定某一個(gè)行為被執(zhí)行的頻率
2. 或者先定義行為(回調(diào)函數(shù)), 然后通過屬性tasks來指定每一個(gè)行為被執(zhí)行的頻率 tasks=[fun1, fun2....] 或者 tasks={fun1:weight1, fun2:weight2......}
3. 不管怎樣定義, 里邊的行為或函數(shù)是被隨機(jī)調(diào)用/執(zhí)行的, 只是根據(jù)weight的不通, 隨機(jī)到的頻率不通而已
4. 而且, 行為/任務(wù)可以嵌套執(zhí)行, 先執(zhí)行task1(也就是 fun1 下同), 然后執(zhí)行task2 ..... 這樣會(huì)更真實(shí)的模擬,
其寫法就是, 將這些有關(guān)聯(lián)任務(wù)定義/封裝到一個(gè)taskset子類中, 然后通過上邊介紹的 tasks屬性tasks={classname:weight}, 在另一個(gè)TaskSet子類中去關(guān)聯(lián)該類以達(dá)到嵌套的目的
5. 在執(zhí)行子任務(wù)時(shí), 通過 self.interrupt() 來終止子任務(wù)的執(zhí)行, 來回到父任務(wù)類中執(zhí)行, 否則子任務(wù)會(huì)一直執(zhí)行
6. 成員函數(shù), on_start(), 如果定義的話, 就會(huì)在開始的時(shí)候執(zhí)行
HttpLocust類
1. 他可以發(fā)送http請求, 他有一個(gè)屬性叫client(實(shí)例化的時(shí)候自動(dòng)生成), 存儲(chǔ)HttpSession類的實(shí)例(HttpSession類在實(shí)例化Locust的時(shí)候自動(dòng)創(chuàng)建), 用來保存請求session
2. TaskSet類里也有屬性client: self.client.get()或者self.client.post(), 這個(gè)client內(nèi)部就是httplocust里的client
3. 請求返回一個(gè)對(duì)象, 他有兩個(gè)成員, response.status_code 和 response.content
4. 如果因連接失敗, 超時(shí)等等原因造成請求失敗, 不會(huì)發(fā)出異常, 而是將上邊的content置為空, status_code 置為0
5. 可以對(duì)返回content內(nèi)容自定義處理, 因?yàn)橛械臅r(shí)候返回404是你希望得到的
1 with client.get("/does_not_exist/", catch_response=True) as response: 2 if response.status_code == 404: 3 response.success()
6.對(duì)網(wǎng)站來說, 一個(gè)URL的參數(shù)是固定的, 但是參數(shù)值是不定的, 也可以處理
Locust功能
在代碼中定義用戶行為
不需要笨重的用戶界面或臃腫的XML。只是簡單的代碼。
分布式和可擴(kuò)展性
Locust支持運(yùn)行分布在多臺(tái)機(jī)器上的負(fù)載測試,因此可以用來模擬數(shù)百萬個(gè)同步用戶。
經(jīng)過驗(yàn)證和實(shí)戰(zhàn)檢驗(yàn)
Locust已經(jīng)被用來模擬數(shù)百萬的同時(shí)用戶。戰(zhàn)地游戲的網(wǎng)頁應(yīng)用Battlelog就是使用Locust進(jìn)行負(fù)載測試的,所以真的可以說Locust是經(jīng)過戰(zhàn)地測試的;)。)
Locust評(píng)測
Locust,提供專業(yè)的測試服務(wù),帶給小伙伴更多的測試便利!



































