溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python獲取接口請(qǐng)求耗時(shí)的方法是什么

發(fā)布時(shí)間:2023-04-17 16:15:10 來源:億速云 閱讀:137 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“Python獲取接口請(qǐng)求耗時(shí)的方法是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

舉例代碼:

import socket
import time

def funcRunTimes(func):
    def wrapper(*args):
        startTime = time.time()
        result = func(*args)
        endTime = time.time()
        execTime = endTime - startTime
        return (result,execTime)
    return wrapper

@funcRunTimes
def shakeHands(hosts,port):
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    try:
        s.connect((hosts, port))
        return s
    except Exception as e:
        print(e)
        return None

@funcRunTimes
def websiteResponseTime(fd,methods,url):
    sendMsgs = "%s %s HTTP/1.1\r\nHost: 127.0.0.1:8080\r\n\r\n" %(methods,url)
    fd.send(sendMsgs.encode())
    recv_data = ""
    while True:
        recv_data = str(fd.recv(15))
        break

    httpCode = recv_data.split(" ")[1]
    return httpCode

def main():
    hosts = "www.juejin.cn"
    port = 80

    methods = "GET"
    url = "/"

    print("執(zhí)行命令為: %s %s:%d %s\n" % (methods, hosts, port, url))

    shakeInfo = shakeHands(hosts,port)
    if shakeInfo == None:
      print("errors")
      return
    responseInfo = websiteResponseTime(shakeInfo[0],methods,url)
    print("接口狀態(tài)碼為:" , responseInfo[0],"握手耗時(shí): %.6fs" %(shakeInfo[1]) , "請(qǐng)求接口耗時(shí): %.6fs" %(responseInfo[1]) ,"總共耗時(shí)為: %.6fs" % (shakeInfo[1] + responseInfo[1]))

if __name__ == '__main__':
    main()

項(xiàng)目中使用了python裝飾器,若還對(duì)python裝飾器不太了解的小伙伴,可以參考一下下面這篇文章:python | 探尋python裝飾器

項(xiàng)目展示

打開項(xiàng)目,修改hosts、portmethods以及url的變量,即可運(yùn)行python程序便可獲得該頁面的詳細(xì)信息的時(shí)間,其中包括TCP/IP三次握手時(shí)間 以及 請(qǐng)求接口耗時(shí),最后是 總的耗時(shí),

Python獲取接口請(qǐng)求耗時(shí)的方法是什么

如何獲得握手時(shí)間

在獲取握手時(shí)間的時(shí)候,不能使用http庫,例如: requests,因?yàn)樗J(rèn)會(huì)進(jìn)行tcp/ip三次握手,而后再進(jìn)行資源請(qǐng)求,所以我們要使用socket來做這個(gè)需求。

python中,socket提供了一種跨平臺(tái)的網(wǎng)絡(luò)通信接口,可以用它來創(chuàng)建各種類型的網(wǎng)絡(luò)連接。

例如代碼如下:

import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('127.0.0.1', 8080))

在上面的代碼中,我們先導(dǎo)入socket庫,而后使用socket.socket()創(chuàng)建一個(gè)socket句柄,而中間的參數(shù)分別代表的意思為:

  • socket.AF_INET: 指定IPv4協(xié)議。

  • socket.SOCK_STREAM: 指定使用TCP流式套接字類型。

s.connect則開始連接服務(wù)器,其參數(shù)類型為元組類型,參數(shù)值為遠(yuǎn)程主機(jī)名 和 遠(yuǎn)程端口。

如上代碼,當(dāng)遠(yuǎn)程服務(wù)器連不上的時(shí)候或者其他異常的時(shí)候,該代碼會(huì)拋異常,若沒有異常,則證明端口通的。

我們僅需要在此之前和之后,都拉一下當(dāng)前時(shí)間戳,就可以計(jì)算出握手所耗費(fèi)的時(shí)間,例如:

import socket
import time
try:
    startTime = time.time()
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    s.connect(('127.0.0.1', 8080))
    endTime = time.time()
    print("runtimes: " , endTime-startTime)
except Exception as e:
    print("捕獲異常" , e)

若沒有拋錯(cuò),我們即可獲得握手時(shí)間。

如何獲得請(qǐng)求時(shí)間

握手成功后,我們就可以向該服務(wù)器發(fā)送http報(bào)文了,注意最簡(jiǎn)單報(bào)文的格式是:

請(qǐng)求方法 請(qǐng)求路由 版本號(hào)
請(qǐng)求頭(主機(jī)名)
空行

例如:

GET / HTTP/1.1
Host: 127.0.0.1:8080

如果我們不添加Host請(qǐng)求頭,則會(huì)拋錯(cuò): HTTP/1.1 400 Bad Request: missing required Host header。

python中,我們直接使用s.send()函數(shù)即可發(fā)送請(qǐng)求,例如:

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('127.0.0.1', 8080))
s.send(b"GET / HTTP/1.1\r\nHost: 127.0.0.1:8080\r\n\r\n")

上述代碼中,\r\n是換行的意思,也稱之為CRLF,注意最后的2個(gè)\r\n是有一個(gè)空行,來標(biāo)志http請(qǐng)求頭的結(jié)束。

一般來說,我們請(qǐng)求接口后,會(huì)讀取服務(wù)器返回來的狀態(tài)碼,以便開發(fā)驗(yàn)證是否是成功的。

這里可以使用s.recv()函數(shù)來讀取服務(wù)器傳回來的信息,例如讀取從服務(wù)器返回的15個(gè)字節(jié)s.recv(15)。

我們可以參考計(jì)算握手時(shí)間的方法,來計(jì)算一下資源請(qǐng)求的時(shí)間,代碼如下:

import socket
import time
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('127.0.0.1', 8080))

startTime = time.time()
s.send(b"GET / HTTP/1.1\r\nHost: 127.0.0.1:8080\r\n\r\n")
recv_data = str(s.recv(15))
endTime = time.time()
print("runtimes: ", endTime - startTime,"接口返回狀態(tài)碼: " , recv_data.split(" ")[1])

如果遠(yuǎn)程主機(jī)和遠(yuǎn)程端口都正常的話,我們大概會(huì)得到如下的信息:

Python獲取接口請(qǐng)求耗時(shí)的方法是什么

善用裝飾器

我們計(jì)算握手時(shí)間,和計(jì)算資源請(qǐng)求時(shí)間,都是相同的代碼,因?yàn)橛?jì)算的功能不同,所以我們需要被迫寫2次,這個(gè)時(shí)候,就可以使用裝飾器,來把這個(gè)額外非核心功能給抽離出來,而將計(jì)算握手和計(jì)算資源請(qǐng)求都給封裝為函數(shù),而后通過函數(shù)來調(diào)用裝飾器,就可以獲取2種請(qǐng)求時(shí)間了。

我們先將裝飾器抽離出來:

def funcRunTimes(func):
    def wrapper(*args):
        startTime = time.time()
        result = func(*args)
        endTime = time.time()
        execTime = endTime - startTime
        return (result,execTime)
    return wrapper

我們?cè)?code>funcRunTimes中直接返回wrapper函數(shù),而在wrapper函數(shù)中,定義開始時(shí)間和結(jié)束時(shí)間,在二者的中間執(zhí)行函數(shù)func,最后將func的結(jié)果以及函數(shù)執(zhí)行的時(shí)間封裝為一個(gè)元組進(jìn)行返回。

此時(shí),我們可以封裝函數(shù)了,例如我們想獲取握手的時(shí)間,我們可以這樣寫:

@funcRunTimes
def shakeHands(hosts,port):
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    try:
        s.connect((hosts, port))
        return s
    except Exception as e:
        print(e)
        return None

如果該遠(yuǎn)程主機(jī)可以連上,我們直接返回socket句柄,若連接不上,直接打印錯(cuò)誤,返回None。

調(diào)用該函數(shù)的是,我們接收返回值即可:

shakeInfo = shakeHands(hosts,port)

注意,shakeInfo是一個(gè)元組,有2個(gè)元組,第一個(gè)是socket句柄,第二個(gè)是執(zhí)行該函數(shù)所需要的時(shí)間。

我們?cè)賹①Y源請(qǐng)求函數(shù)封裝一下,就可以完成這個(gè)項(xiàng)目了。

“Python獲取接口請(qǐng)求耗時(shí)的方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI