2015年7月17日 22:19:17 星期五
這里記錄下學(xué)習(xí)道路, 防止忘了
操作系統(tǒng)是centos:
首先是linux系統(tǒng), 裝有Python 和 Python-devel (否則安裝軟件會(huì)提示python.h找不到, gcc error等問題...... )
1 yum install - y python 2 yum install -y python-devel
然后安裝pip
下載 get-pip.py 文件到linux
運(yùn)行Python 命令執(zhí)行該文件:?
python get-pip.py
安裝 greenlet (協(xié)程/微線程)
pip
install
greenlet
安裝 gevent (網(wǎng)絡(luò)io用)
pip
install
gevent
安裝locustio:?
pip
install
locustio
進(jìn)行壓測(cè)
locust --host=http: // 127.0.0.1 --port=8089 -f ./test.py
locustio有自己的web頁(yè)面, 上邊的命令意思是: 在瀏覽器里打開 http://127.0.0.1:8089 顯示locustio的web控制頁(yè)面, 需要被壓測(cè)的網(wǎng)站域名和URL放在test.py里
====================
下邊列出缺少python-devel(Ubuntu: python-dev)包時(shí)的錯(cuò)誤信息, 可以通過百度搜索, 讓出錯(cuò)的同學(xué)搜索到本篇文章解決類似的問題
Command "/usr/bin/python -c "import setuptools, tokenize;__file__='/tmp/pip-build-6zEhZN/greenlet/setup.py';exec(compile(getattr(tokenize, 'open', open)(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --record /tmp/pip-dEs44u-record/install-record.txt --single-version-externally-managed --compile" failed with error code 1 in /tmp/pip-build-6zEhZN/greenlet
============
概念理解( 翻譯 ):
1. 超級(jí)類是 locust 類,它的每一個(gè)實(shí)例代表了一個(gè)用戶, 守護(hù)程序會(huì)為每一個(gè)模擬用戶生成一個(gè)實(shí)例
2. httplocust 繼承了locust 類, 添加了可以發(fā)送http請(qǐng)求的功能
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 就是需要被壓測(cè)的網(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請(qǐng)求, 他有一個(gè)屬性叫client(實(shí)例化的時(shí)候自動(dòng)生成), 存儲(chǔ)HttpSession類的實(shí)例(HttpSession類在實(shí)例化Locust的時(shí)候自動(dòng)創(chuàng)建), 用來保存請(qǐng)求session
2. TaskSet類里也有屬性client: self.client.get()或者self.client.post(), 這個(gè)client內(nèi)部就是httplocust里的client
3. 請(qǐng)求返回一個(gè)對(duì)象, 他有兩個(gè)成員, response . status_code 和 response . content
4. 如果因連接失敗, 超時(shí)等等原因造成請(qǐng)求失敗, 不會(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ù)值是不定的, 也可以處理
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可以擴(kuò)展開發(fā), 有需要的可以去看官方文檔, 內(nèi)容沒多少
?
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
