概念理解(翻譯):
- 超級類是 locust 類
它的每一個實例代表了一個用戶, 守護程序會為每一個模擬用戶生成一個實例 - httplocust 繼承了locust 類, 添加了可以發(fā)送http請求的功能
- locust 有一個屬性(成員變量)是 task_set , 它可以定義用戶的行為, 就是訪問哪些URL, post還是get, 每個連接占總訪問量比是多少
這個task_set 是類TaskSet(或其子類)的一個實例, 上邊說的各種行為就是在這個類里邊定義的
locsut類:
屬性: min_wait/max_wait
模擬用戶有在上邊說的類中定義了好多任務/行為, 每個任務/行為間隔多久執(zhí)行一次, 單位是毫秒, 默認1000, 也即隔一秒種后執(zhí)行下一個任務
**屬性: weight 權重: **
模擬時, 同一段時間, 手機用戶的訪問量要比PC的訪問量大, 那么對應的locust(或其子類)的weight值就大小不一
**屬性: host **
就是需要被壓測的網(wǎng)站的域名(或域名前綴), 如果啟動服務時沒有通過參數(shù)-host來指定域名, 那么就用使用該host屬性指定的值
TaskSet類:
- 推薦的是, 在taskset類(或子類)中通過在行為(回調(diào)函數(shù))前加@task(weight)描述符來指定某一個行為被執(zhí)行的頻率
- 或者先定義行為(回調(diào)函數(shù)), 然后通過屬性tasks來指定每一個行為被執(zhí)行的頻率 tasks=[fun1, fun2....] 或者 tasks={fun1:weight1, fun2:weight2......}
- 不管怎樣定義, 里邊的行為或函數(shù)是被隨機調(diào)用/執(zhí)行的, 只是根據(jù)weight的不通, 隨機到的頻率不通而已
- 而且, 行為/任務可以嵌套執(zhí)行, 先執(zhí)行task1(也就是 fun1 下同), 然后執(zhí)行task2 ..... 這樣會更真實的模擬,
其寫法就是, 將這些有關聯(lián)任務定義/封裝到一個taskset子類中, 然后通過上邊介紹的 tasks屬性tasks={classname:weight}, 在另一個TaskSet子類中去關聯(lián)該類以達到嵌套的目的 - 在執(zhí)行子任務時, 通過 self.interrupt() 來終止子任務的執(zhí)行, 來回到父任務類中執(zhí)行, 否則子任務會一直執(zhí)行
- 成員函數(shù), on_start(), 如果定義的話, 就會在開始的時候執(zhí)行
HttpLocust類
- 他可以發(fā)送http請求, 他有一個屬性叫client(實例化的時候自動生成), 存儲HttpSession類的實例(HttpSession類在實例化Locust的時候自動創(chuàng)建), 用來保存請求session
- TaskSet類里也有屬性client: self.client.get()或者self.client.post(), 這個client內(nèi)部就是httplocust里的client
- 請求返回一個對象, 他有兩個成員, response.status_code 和 response.content
- 如果因連接失敗, 超時等等原因造成請求失敗, 不會發(fā)出異常, 而是將上邊的content置為空, status_code 置為0
- 可以對返回content內(nèi)容自定義處理, 因為有的時候返回404是你希望得到的
1 with client.get("/does_not_exist/", catch_response=True) as response:2 if response.status_code == 404:3 response.success()
6.對網(wǎng)站來說, 一個URL的參數(shù)是固定的, 但是參數(shù)值是不定的, 也可以處理
1 # Statistics for these requests will be grouped under: /blog/?id=[id]2 for i in range(10):3 client.get("/blog?id=%i" % i, name="/blog?id=[id]")
其他, locust還有很多事件hook可以擴展開發(fā), 有需要的可以去看官方文檔, 內(nèi)容沒多少