Requests-handling-timeouts

提供:Dev Guides
移動先:案内検索

リクエスト-タイムアウトの処理

タイムアウトは、リクエストしているURLに簡単に追加できます。 たまたま、サードパーティのURLを使用していて、応答を待っています。 応答またはエラーでURLをタイムスパン内で応答させたい場合があるため、URLにタイムアウトを設定することは常に良い習慣です。 そうしないと、その要求を無期限に待機させる可能性があります。

以下の例に示すように、timeout paramを使用してURLにタイムアウトを与えることができ、値は秒単位で渡されます-

import requests
getdata =
requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)

出力

raise ConnectTimeout(e, request=request)
requests.exceptions.ConnectTimeout:
HTTPSConnectionPool(host='jsonplaceholder.typicode.com',
port=443): Max retries exceeded with url:/users (Caused
by Connect
TimeoutError(<urllib3.connection.VerifiedHTTPSConnection object at
0x000000B02AD
E76A0>, 'Connection to jsonplaceholder.typicode.com timed out. (connect
timeout = 0.001)'))

与えられたタイムアウトは次のとおりです-

getdata =
requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)

出力に示すように、実行により接続タイムアウトエラーがスローされます。 指定されたタイムアウトは0.001です。これは、要求が応答を取得してエラーをスローすることは不可能です。 ここで、タイムアウトを増やして確認します。

import requests
getdata =
requests.get('https://jsonplaceholder.typicode.com/users',timeout=1.000)
print(getdata.text)

出力

E:\prequests>python makeRequest.py
[
   {
      "id": 1,
      "name": "Leanne Graham",
      "username": "Bret",
      "email": "[email protected]",
      "address": {
         "street": "Kulas Light",
         "suite": "Apt. 556",
         "city": "Gwenborough",
         "zipcode": "92998-3874",
         "geo": {
            "lat": "-37.3159",
            "lng": "81.1496"
         }
      },
      "phone": "1-770-736-8031 x56442",
      "website": "hildegard.org",
      "company": {
         "name": "Romaguera-Crona",
         "catchPhrase": "Multi-layered client-server neural-net",
         "bs": "harness real-time e-markets"
      }
   }
]

1秒のタイムアウトで、要求されたURLに対する応答を取得できます。