python+requests接口壓力測(cè)試500次,查看響應(yīng)時(shí)間的實(shí)例
接口壓力測(cè)試500次,查看響應(yīng)時(shí)間
import json
import requests
import logging
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)
restime = []
OK=[]
class Restime():
def API(self,URL2,param):
try:
r = requests.get(URL2, params=param, timeout=10)
r.raise_for_status() # 如果響應(yīng)狀態(tài)碼不是 200,就主動(dòng)拋出異常
except requests.RequestException as e:
print(e)
else:
js = json.dumps(r.json())
return [r.json(), r.elapsed.total_seconds(),js]
def circulation(self,num,URL2,param):
for i in range(num):
restime.append(Restime.API(URL2,param)[1])
if json.loads(Restime.API(URL2, param)[2])["message"]=='ok':
OK.append(json.loads(Restime.API(URL2, param)[2])["message"])
logger.info('請(qǐng)求第' + str(i+1) + '次,請(qǐng)求'+json.loads(Restime.API(URL2, param)[2])["message"]+',狀態(tài)碼:'+json.loads(Restime.API(URL2, param)[2])["status"])
else:
logger.info('請(qǐng)求第' + str(i+1) + '次,請(qǐng)求' + json.loads(Restime.API(URL2, param)[2])["message"] + ',狀態(tài)碼:' +
json.loads(Restime.API(URL2, param)[2])["status"])
print('測(cè)試次數(shù):',num)
print('響應(yīng)次數(shù):', len(restime))
print('正常響應(yīng)次數(shù):', len(OK))
print('總響應(yīng)最大時(shí)長(zhǎng):', max(restime))
print('總響應(yīng)最小時(shí)長(zhǎng):', min(restime))
print('總響應(yīng)時(shí)長(zhǎng):', sum(restime))
print('平均響應(yīng)時(shí)長(zhǎng):', sum(restime) / len(restime))
if __name__ == '__main__':
Restime=Restime()
#URL2 = 'http://wthrcdn.etouch.cn/weather_mini'
#param = {'ip': '8.8.8.8', 'city': '西安'}
num=500 #壓力測(cè)試次數(shù)
URL2 = 'http://www.kuaidi100.com/query' #地址
param = {'type' : 'zhongtong' , 'postid' :'73116039505988' } #參數(shù)
Restime.circulation(num,URL2,param)
input('Press Enter to exit...')
測(cè)試次數(shù): 500 響應(yīng)次數(shù): 500 正常響應(yīng)次數(shù): 500 總響應(yīng)最大時(shí)長(zhǎng): 0.336179 總響應(yīng)最小時(shí)長(zhǎng): 0.062753 總響應(yīng)時(shí)長(zhǎng): 41.892936000000034 平均響應(yīng)時(shí)長(zhǎng): 0.08378587200000007

補(bǔ)充知識(shí):python利用requests統(tǒng)計(jì)1個(gè)接口的響應(yīng)時(shí)間
requests統(tǒng)計(jì)接口的響應(yīng)時(shí)間有2種方式
r.elapsed.total_seconds()
r.elapsed.microseconds/(1000*1000)
但是第2種方式,當(dāng)調(diào)用的接口響應(yīng)時(shí)間大于1s時(shí),得到的響應(yīng)時(shí)間是不準(zhǔn)確的。下面來(lái)看示例
首先看接口響應(yīng)時(shí)間小于1s時(shí),分別使用2種方式得到 post "https://www.baidu.com/" 的響應(yīng)時(shí)間
代碼示例:
import requests url = "https://www.baidu.com/" r = requests.post(url) # print(r.text) #推薦使用這種方式統(tǒng)計(jì)一個(gè)接口的響應(yīng)時(shí)間,準(zhǔn)確性更高 print(r.elapsed.total_seconds()) #當(dāng)接口的響應(yīng)時(shí)間大于1s時(shí),下面這種統(tǒng)計(jì)方式就會(huì)不準(zhǔn)確 print(r.elapsed.microseconds/(1000*1000))
運(yùn)行結(jié)果:
0.039872
0.039872
再測(cè)試一個(gè)接口響應(yīng)時(shí)間超過(guò)1s的接口,
然后看接口響應(yīng)時(shí)間大于1s時(shí),分別使用2種方式得到 post "http://cn.python-requests.org/zh_CN/1atest/" 的響應(yīng)時(shí)間
果然發(fā)現(xiàn)2種方式統(tǒng)計(jì)的結(jié)果不一樣了呢
import requests url = "http://cn.python-requests.org/zh_CN/1atest/" r = requests.post(url) # print(r.text) #結(jié)果正確 print(r.elapsed.total_seconds()) #結(jié)果不正確 print(r.elapsed.microseconds/(1000*1000))
運(yùn)行結(jié)果:
1.298427
0.298427
很顯然,r.elapsed.microseconds/(1000*1000)在接口的響應(yīng)時(shí)間大于1s時(shí),只截取了后面的小數(shù)部分
以上這篇python+requests接口壓力測(cè)試500次,查看響應(yīng)時(shí)間的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python機(jī)器學(xué)習(xí)之Kmeans基礎(chǔ)算法
這篇文章主要介紹了Python機(jī)器學(xué)習(xí)之Kmeans基礎(chǔ)算法,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-04-04
Django連接數(shù)據(jù)庫(kù)并實(shí)現(xiàn)讀寫(xiě)分離過(guò)程解析
這篇文章主要介紹了Django連接數(shù)據(jù)庫(kù)并實(shí)現(xiàn)讀寫(xiě)分離過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
Python 實(shí)現(xiàn)list,tuple,str和dict之間的相互轉(zhuǎn)換
這篇文章主要介紹了Python 實(shí)現(xiàn)list,tuple,str和dict之間的相互轉(zhuǎn)換,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03
Python NumPy中的隨機(jī)數(shù)及ufuncs函數(shù)使用示例詳解
這篇文章主要介紹了Python NumPy中的隨機(jī)數(shù)及ufuncs函數(shù)使用,ufunc函數(shù)是NumPy中的一種通用函數(shù),它可以對(duì)數(shù)組中的每個(gè)元素進(jìn)行操作,而不需要使用循環(huán)語(yǔ)句,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-05-05
python如何導(dǎo)出微信公眾號(hào)文章方法詳解
這篇文章主要介紹了python如何導(dǎo)出微信公眾號(hào)文章方法詳解,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
關(guān)于nn.BatchNorm1d()用法及說(shuō)明
這篇文章主要介紹了關(guān)于nn.BatchNorm1d()用法及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08

