Сервер asyncio не отменяет запрос, даже если aiohttp.ClientSession превышает таймаутPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Сервер asyncio не отменяет запрос, даже если aiohttp.ClientSession превышает таймаут

Сообщение Anonymous »

Конечная цель — отменить запрос на стороне сервера, если клиент превышает время ожидания.
Вот мой код конечной точки:

Код: Выделить всё

@routes.get('/ping')
async def handle_ping(_) -> web.Response:
try:
import time
import asyncio
for i in range(10):
await asyncio.sleep(1)

return web.json_response(
data=PingResult(
service_name=service_name,
version=SERVICE_VERSION,
storage_path=str(storage_dir.path),
daemon_pid=daemon.pid,
daemon_status=str(daemon.status.value),
).dict()
)
except asyncio.CancelledError as ce:
print('Request was cancelled')
return HTTPBadRequest(ErrorResult(error='Request was cancelled'))
Код клиента

Код: Выделить всё

async def ping(timeout=10) -> PingResult:
async with aiohttp.ClientSession(timeout=ClientTimeout(total=timeout)) as session:
async with session.get('http://localhost:5002/ping') as resp:
body = await resp.json()
return PingResult.parse_obj(body)
Модели

Код: Выделить всё

from aiohttp import web
from pydantic import BaseModel

class ErrorResult(TypedDict):
error: str

class HTTPBadRequest(web.HTTPBadRequest):
def __init__(self, error: Mapping) -> None:
super().__init__(text=dumps(error), content_type='application/json')

class PingResult(BaseModel):
service_name: str
version: str
storage_path: str
daemon_pid: int
daemon_status: str
Даже если я вызову ping(timeout=2), я увижу, что запрос на сервере не был отменен. Или, если я вызову curl http://localhost:5002/ping и завершу команду менее чем за 2–3 секунды, я получу такое же поведение (код на стороне сервера работает без какого-либо завершения).
Похоже, я неправильно понимаю саму идею отмены запроса, но я могу понять, как мне достичь своей главной цели.


Подробнее здесь: https://stackoverflow.com/questions/791 ... exceeds-it
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»