欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python+requests接口壓力測(cè)試500次,查看響應(yīng)時(shí)間的實(shí)例

 更新時(shí)間:2020年04月30日 10:59:15   作者:默金……  
這篇文章主要介紹了python+requests接口壓力測(cè)試500次,查看響應(yīng)時(shí)間的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

接口壓力測(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í)長:', max(restime))
  print('總響應(yīng)最小時(shí)長:', min(restime))
  print('總響應(yīng)時(shí)長:', sum(restime))
  print('平均響應(yīng)時(shí)長:', 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í)長: 0.336179
總響應(yīng)最小時(shí)長: 0.062753
總響應(yīng)時(shí)長: 41.892936000000034
平均響應(yīng)時(shí)長: 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)確的。下面來看示例

首先看接口響應(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í)間超過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í)例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python裝飾器代替set get方法實(shí)例

    python裝飾器代替set get方法實(shí)例

    今天小編就為大家分享一篇python裝飾器代替set get方法實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • Python自省及反射原理實(shí)例詳解

    Python自省及反射原理實(shí)例詳解

    這篇文章主要介紹了Python自省及反射原理實(shí)例詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Anaconda超詳細(xì)保姆級(jí)安裝配置教程

    Anaconda超詳細(xì)保姆級(jí)安裝配置教程

    這篇文章主要介紹了Anaconda超詳細(xì)保姆級(jí)安裝配置教程,本篇教程對(duì)于新手很友好強(qiáng)烈推薦,看完這篇文章相信你對(duì)如何安裝配置Anaconda一定了然于胸,我們一起來看看吧
    2023-03-03
  • python打開瀏覽器并模擬搜索示例詳解

    python打開瀏覽器并模擬搜索示例詳解

    這篇文章主要為大家介紹了python打開瀏覽器并模擬搜索示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • bat和python批量重命名文件的實(shí)現(xiàn)代碼

    bat和python批量重命名文件的實(shí)現(xiàn)代碼

    這篇文章主要介紹了bat和python批量重命名文件的實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2016-05-05
  • Python簡繁體轉(zhuǎn)換的簡單實(shí)現(xiàn)步驟

    Python簡繁體轉(zhuǎn)換的簡單實(shí)現(xiàn)步驟

    工作中需要將繁體中文轉(zhuǎn)換成簡體中文上網(wǎng)找了些資料,下面這篇文章主要給大家介紹了關(guān)于Python實(shí)現(xiàn)簡繁體轉(zhuǎn)換的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Python 隱藏輸入密碼時(shí)屏幕回顯的實(shí)例

    Python 隱藏輸入密碼時(shí)屏幕回顯的實(shí)例

    今天小編就為大家分享一篇Python 隱藏輸入密碼時(shí)屏幕回顯的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • python數(shù)據(jù)可視化之條形圖畫法

    python數(shù)據(jù)可視化之條形圖畫法

    這篇文章主要為大家詳細(xì)介紹了python數(shù)據(jù)可視化之條形圖畫法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Python屬性和內(nèi)建屬性實(shí)例解析

    Python屬性和內(nèi)建屬性實(shí)例解析

    這篇文章主要介紹了Python屬性和內(nèi)建屬性實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • TensorFlow查看輸入節(jié)點(diǎn)和輸出節(jié)點(diǎn)名稱方式

    TensorFlow查看輸入節(jié)點(diǎn)和輸出節(jié)點(diǎn)名稱方式

    今天小編就為大家分享一篇TensorFlow查看輸入節(jié)點(diǎn)和輸出節(jié)點(diǎn)名稱方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01

最新評(píng)論