中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python+requests如何實現接口壓力測試500次,查看響應時間

發布時間:2020-07-29 12:21:10 來源:億速云 閱讀:446 作者:小豬 欄目:開發技術

這篇文章主要講解了python+requests如何實現接口壓力測試500次,查看響應時間,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

接口壓力測試500次,查看響應時間

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() # 如果響應狀態碼不是 200,就主動拋出異常
  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('請求第' + str(i+1) + '次,請求'+json.loads(Restime.API(URL2, param)[2])["message"]+',狀態碼:'+json.loads(Restime.API(URL2, param)[2])["status"])
   else:
    logger.info('請求第' + str(i+1) + '次,請求' + json.loads(Restime.API(URL2, param)[2])["message"] + ',狀態碼:' +
       json.loads(Restime.API(URL2, param)[2])["status"])
  print('測試次數:',num)
  print('響應次數:', len(restime))
  print('正常響應次數:', len(OK))
  print('總響應最大時長:', max(restime))
  print('總響應最小時長:', min(restime))
  print('總響應時長:', sum(restime))
  print('平均響應時長:', 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 #壓力測試次數
 URL2 = 'http://www.kuaidi100.com/query' #地址
 param = {'type' : 'zhongtong' , 'postid' :'73116039505988' } #參數
 Restime.circulation(num,URL2,param)
 input('Press Enter to exit...')
測試次數: 500
響應次數: 500
正常響應次數: 500
總響應最大時長: 0.336179
總響應最小時長: 0.062753
總響應時長: 41.892936000000034
平均響應時長: 0.08378587200000007

python+requests如何實現接口壓力測試500次,查看響應時間

補充知識:python利用requests統計1個接口的響應時間

requests統計接口的響應時間有2種方式

r.elapsed.total_seconds()
r.elapsed.microseconds/(1000*1000)

但是第2種方式,當調用的接口響應時間大于1s時,得到的響應時間是不準確的。下面來看示例

首先看接口響應時間小于1s時,分別使用2種方式得到 post "https://www.baidu.com/" 的響應時間

代碼示例:

import requests
url = "https://www.baidu.com/"
r = requests.post(url)
# print(r.text)
#推薦使用這種方式統計一個接口的響應時間,準確性更高
print(r.elapsed.total_seconds())
#當接口的響應時間大于1s時,下面這種統計方式就會不準確
print(r.elapsed.microseconds/(1000*1000))

運行結果:

0.039872
0.039872

再測試一個接口響應時間超過1s的接口,

然后看接口響應時間大于1s時,分別使用2種方式得到 post "http://cn.python-requests.org/zh_CN/1atest/" 的響應時間

果然發現2種方式統計的結果不一樣了呢

import requests
url = "http://cn.python-requests.org/zh_CN/1atest/"
r = requests.post(url)
# print(r.text)
#結果正確
print(r.elapsed.total_seconds())
#結果不正確
print(r.elapsed.microseconds/(1000*1000))

運行結果:

1.298427
0.298427

很顯然,r.elapsed.microseconds/(1000*1000)在接口的響應時間大于1s時,只截取了后面的小數部分

看完上述內容,是不是對python+requests如何實現接口壓力測試500次,查看響應時間有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

奉化市| 曲水县| 秦安县| 夏邑县| 阜新| 达尔| 尼玛县| 山东省| 台安县| 印江| 丰台区| 柘荣县| 镇康县| 林口县| 衢州市| 壤塘县| 宜丰县| 丹寨县| 民县| 永登县| 毕节市| 宝坻区| 都昌县| 南部县| 昌宁县| 凤庆县| 邛崃市| 萨嘎县| 延安市| 陆良县| 丹江口市| 扶沟县| 遵义市| 东阿县| 新巴尔虎左旗| 当涂县| 三门县| 木兰县| 库尔勒市| 江川县| 青冈县|