python輕量級(jí)性能工具-Locust詳解
Locust基于python的協(xié)程機(jī)制,打破了線程進(jìn)程的限制,可以能夠在一臺(tái)測(cè)試機(jī)上跑高并發(fā)
性能測(cè)試基礎(chǔ)
1.快慢:衡量系統(tǒng)的處理效率:響應(yīng)時(shí)間
2.多少:衡量系統(tǒng)的處理能力:?jiǎn)挝粫r(shí)間內(nèi)能處理多少個(gè)事務(wù)(tps)
性能測(cè)試根據(jù)測(cè)試需求最常見的分為下面三類
1 負(fù)載測(cè)試load testing
不斷向服務(wù)器加壓,值得預(yù)定的指標(biāo)或者部分系統(tǒng)資源達(dá)到瓶頸,目的是找到系統(tǒng)最大負(fù)載的能力
2 壓力測(cè)試
通過(guò)高負(fù)載持續(xù)長(zhǎng)時(shí)間,來(lái)驗(yàn)證系統(tǒng)是否穩(wěn)定
3 并發(fā)測(cè)試:
同時(shí)像服務(wù)器提交請(qǐng)求,目的發(fā)現(xiàn)系統(tǒng)是否存在事務(wù)沖突或者鎖升級(jí)的現(xiàn)象
性能負(fù)載模型

locust安裝
安裝存在問(wèn)題,可以通過(guò)豆瓣源下載
pip install locust
locust模板
基本上多數(shù)的場(chǎng)景我們都可以基于這個(gè)模板read.py去做修改
from locust import HttpUser, TaskSet, task, tag, events
# 啟動(dòng)locust時(shí)運(yùn)行
@events.test_start.add_listener
def setup(environment, **kwargs):
# print("task setup")
# 停止locust時(shí)運(yùn)行
@events.test_stop.add_listener
def teardown(environment, **kwargs):
print("task teardown")
class UserBehavor(TaskSet):
#虛擬用戶啟用task運(yùn)行
def on_start(self):
print("start")
locusts_spawned.wait()
#虛擬用戶結(jié)束task運(yùn)行
def on_stop(self):
print("stop")
@tag('test1')
@task(2)
def index(self):
self.client.get('/yetangjian/p/17320268.html')
@task(1)
def info(self):
self.client.get("/yetangjian/p/17253215.html")
class WebsiteUser(HttpUser):
def setup(self):
print("locust setup")
def teardown(self):
print("locust teardown")
host = "https://www.cnblogs.com"
task_set = task(UserBehavor)
min_wait = 3000
max_wait = 5000注:這里我們給了一個(gè)webhost,這樣我們可以直接在瀏覽器中打開locust
集合點(diǎn)lr_rendezvous
當(dāng)然我們可以把集合點(diǎn)操作放入上述模板的setup中去運(yùn)行起來(lái)
locusts_spawned = Semaphore()
locusts_spawned.acquire()
def on_hatch_complete(**kwargs):
"""
select_task類的鉤子函數(shù)
:param kwargs:
:return:
"""
locusts_spawned.release()
events.spawning_complete.add_listener(on_hatch_complete)
n = 0
class UserBehavor(TaskSet):
def login(self):
global n
n += 1
print(f"第{n}個(gè)用戶登陸")
def on_start(self):
self.login()
locusts_spawned.wait()
@task
def test1(self):
#catch_response獲取返回
with self.client.get("/yetangjian/p/17253215.html",catch_response=True):
print("查詢結(jié)束")
class WebsiteUser(HttpUser):
host = "https://www.cnblogs.com"
task_set = task(UserBehavor)
wait_time = between(1,3)
if __name__ == '__main__':
os.system('locust -f read.py --web-host="127.0.0.1"')比較常見的用法
在上面兩個(gè)例子中我們已經(jīng)看到了一些,例如裝飾器events.test_start.add_listener;events.test_stop.add_listener用來(lái)在負(fù)載測(cè)試前后進(jìn)行一些操作,又例如on_start、on_stop,在task執(zhí)行前后運(yùn)行,又例如task,可以用來(lái)分配任務(wù)的權(quán)重
等待時(shí)間
# wait between 3.0 and 10.5 seconds after each task #wait_time = between(3.0, 10.5) #固定時(shí)間等待 # wait_time = constant(3) #確保每秒運(yùn)行多少次 constant_throughput(task_runs_per_second) #確保每多少秒運(yùn)行一次 constant_pacing(wait_time)
同樣也可以在User類下發(fā)重寫wait_time來(lái)達(dá)到自定義
tag標(biāo)記
@tag('test1')
@task(2)
def index(self):
self.client.get('/yetangjian/p/17320268.html')通過(guò)對(duì)任務(wù)打標(biāo)記,就可以在運(yùn)行時(shí)候執(zhí)行運(yùn)行某一些任務(wù):
#只執(zhí)行標(biāo)記test1
os.system('locust -f read.py --tags test1 --web-host="127.0.0.1"')
#不執(zhí)行標(biāo)記過(guò)的
os.system('locust -f read.py --exclude-tags --web-host="127.0.0.1"')
#除去test1執(zhí)行所有
os.system('locust -f read.py --exclude-tags test1 --web-host="127.0.0.1"')自定義失敗
#定義響應(yīng)時(shí)間超過(guò)0.1就為失敗
with self.client.get("/yetangjian/p/17253215.html", catch_response=True) as response:
if response.elapsed.total_seconds() > 0.1:
response.failure("Request took too long")
#定義響應(yīng)碼是200就為失敗
with self.client.get("/yetangjian/p/17320268.html", catch_response=True) as response:
if response.status_code == 200:
response.failure("響應(yīng)碼200,但我定義為失敗")
自定義負(fù)載形狀
自定義一個(gè)shape.py通過(guò)繼承LoadTestShape并重寫tick
這個(gè)形狀類將以100塊為單位,20速率的增加用戶數(shù),然后在10分鐘后停止負(fù)載測(cè)試(從運(yùn)行開始的第51秒開始user_count會(huì)round到100)
from locust import LoadTestShape
class MyCustomShape(LoadTestShape):
time_limit = 600
spawn_rate = 20
def tick(self):
run_time = self.get_run_time()
if run_time < self.time_limit:
# User count rounded to nearest hundred.
user_count = round(run_time, -2)
return (user_count, self.spawn_rate)
return None運(yùn)行圖如下所示

通過(guò)命令行去觸發(fā)
os.system('locust -f read.py,shape.py --web-host="127.0.0.1"')不同時(shí)間階段的例子
from locust import LoadTestShape
class StagesShapeWithCustomUsers(LoadTestShape):
stages = [
{"duration": 10, "users": 10, "spawn_rate": 10},
{"duration": 30, "users": 50, "spawn_rate": 10},
{"duration": 60, "users": 100, "spawn_rate": 10},
{"duration": 120, "users": 100, "spawn_rate": 10}]
def tick(self):
run_time = self.get_run_time()
for stage in self.stages:
if run_time < stage["duration"]:
tick_data = (stage["users"], stage["spawn_rate"])
return tick_data
return None到此這篇關(guān)于python輕量級(jí)性能工具-Locust的文章就介紹到這了,更多相關(guān)python性能工具Locust內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于pytorch的RNN實(shí)現(xiàn)字符級(jí)姓氏文本分類的示例代碼
當(dāng)使用基于PyTorch的RNN實(shí)現(xiàn)字符級(jí)姓氏文本分類時(shí),我們可以使用一個(gè)非常簡(jiǎn)單的RNN模型來(lái)處理輸入的字符序列,并將其應(yīng)用于姓氏分類任務(wù),本文給大家舉了一個(gè)基本的示例代碼,需要的朋友可以參考下2023-12-12
Python代碼顯得Pythonic(區(qū)別于其他語(yǔ)言的寫法)
這篇文章主要介紹了Python代碼顯得Pythonic(區(qū)別于其他語(yǔ)言的寫法),對(duì)于字符串連接,相比于簡(jiǎn)單的+,更pythonic的做法是盡量使用%操作符或者format函數(shù)格式化字符串,感興趣的小伙伴和小編一起進(jìn)入文章了解更詳細(xì)相關(guān)知識(shí)內(nèi)容吧2022-02-02
Python實(shí)現(xiàn)對(duì)桌面進(jìn)行實(shí)時(shí)捕捉畫面的方法詳解
最近在研究目標(biāo)檢測(cè)方面的小東西,需要到對(duì)桌面進(jìn)行實(shí)時(shí)捕捉畫面。所以本文來(lái)用Python實(shí)現(xiàn)簡(jiǎn)單的對(duì)桌面進(jìn)行實(shí)時(shí)捕捉畫面,感興趣的可以了解一下2023-01-01
Python基于當(dāng)前時(shí)間批量創(chuàng)建文件
這篇文章主要介紹了Python基于當(dāng)前時(shí)間批量創(chuàng)建文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
解決python執(zhí)行不輸出系統(tǒng)命令彈框的問(wèn)題
今天小編就為大家分享一篇解決python執(zhí)行不輸出系統(tǒng)命令彈框的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
python如何通過(guò)正則匹配指定字符開頭與結(jié)束提取中間內(nèi)容
這篇文章主要介紹了python通過(guò)正則匹配指定字符開頭與結(jié)束提取中間內(nèi)容的操作方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02
OpenCV+python3實(shí)現(xiàn)視頻分解成圖片
這篇文章主要為大家詳細(xì)介紹了OpenCV+python3實(shí)現(xiàn)視頻分解成圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
Python正則表達(dá)式如何進(jìn)行字符串替換實(shí)例
Python正則表達(dá)式在使用中會(huì)經(jīng)常應(yīng)用到字符串替換的代碼。這篇文章主要介紹了Python正則表達(dá)式如何進(jìn)行字符串替換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-12-12
Python實(shí)現(xiàn)將藍(lán)底照片轉(zhuǎn)化為白底照片功能完整實(shí)例
這篇文章主要介紹了Python實(shí)現(xiàn)將藍(lán)底照片轉(zhuǎn)化為白底照片功能,結(jié)合完整實(shí)例形式分析了Python基于cv2庫(kù)進(jìn)行圖形轉(zhuǎn)換操作的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-12-12

