Solicitações - Tratamento de tempos limite

Timeouts podem ser facilmente adicionados ao URL que você está solicitando. Acontece que você está usando uma URL de terceiros e esperando por uma resposta. É sempre uma boa prática fornecer um tempo limite no URL, pois podemos querer que o URL responda dentro de um intervalo de tempo com uma resposta ou erro. Não fazer isso pode fazer com que a solicitação seja aguardada indefinidamente.

Podemos dar tempo limite ao URL usando o parâmetro de tempo limite e o valor é passado em segundos, conforme mostrado no exemplo abaixo -

Exemplo

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

Resultado

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)'))

O tempo limite fornecido é o seguinte -

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

A execução gera um erro de tempo limite de conexão, conforme mostrado na saída. O tempo limite fornecido é 0,001, o que não é possível para a solicitação de obter a resposta e gera um erro. Agora, vamos aumentar o tempo limite e verificar.

Exemplo

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

Resultado

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"
      }
   }
]

Com um tempo limite de 1 segundo, podemos obter a resposta para o URL solicitado.