Я изучал обработку FastAPI синхронных и асинхронных конечных точек и наткнулся на несколько вещей, которые пытаюсь понять более четко, особенно в отношении того, как операции блокировки ведут себя в Python. >
Насколько я понимаю, когда вызывается синхронный маршрут (определенный с помощью def), FastAPI выгружает его в отдельный поток из пула потоков, чтобы избежать блокировки основного цикла событий. Это имеет смысл, поскольку поток может быть заблокирован (например, time.sleep()), но сам цикл обработки событий не блокируется, поскольку он продолжает обрабатывать другие запросы.
Но вот что мое замешательство: если функция действительно блокирует (например, ожидает чего-то вроде time.sleep()), как цикл событий все еще может одновременно выполнять другие задачи? Разве интерпретатор Python не должен выполнять только один поток за раз?
Вот пример:
from fastapi import APIRouter
import os
import threading
import asyncio
app = APIRouter()
@app.get('/sync')
def tarefa_sincrona():
print('Sync')
total = 0
for i in range(10223424*1043):
total += i
print('Sync task done')
@app.get('/async')
async def tarefa_sincrona():
print('Async task')
await asyncio.sleep(5)
print('Async task done')
< /code>
Если я сделаю два запроса - первые в конечной точке синхронизации, а вторая - в асинхронную конечную точку - почти одновременно, я ожидал, что цикл события будет заблокирован. Однако на самом деле происходит то, что два запроса выполняются «параллельно».>
Подробнее здесь: https://stackoverflow.com/questions/793 ... event-loop
FASTAPI - Почему синхронный код не блокирует цикл события? ⇐ Python
Программы на Python
-
Anonymous
1737674031
Anonymous
Я изучал обработку FastAPI синхронных и асинхронных конечных точек и наткнулся на несколько вещей, которые пытаюсь понять более четко, особенно в отношении того, как операции блокировки ведут себя в Python. >
Насколько я понимаю, когда вызывается синхронный маршрут (определенный с помощью def), FastAPI выгружает его в отдельный поток из пула потоков, чтобы избежать блокировки основного цикла событий. Это имеет смысл, поскольку поток может быть заблокирован (например, time.sleep()), но сам цикл обработки событий не блокируется, поскольку он продолжает обрабатывать другие запросы.
Но вот что мое замешательство: если функция действительно блокирует (например, ожидает чего-то вроде time.sleep()), как цикл событий все еще может одновременно выполнять другие задачи? Разве интерпретатор Python не должен выполнять только один поток за раз?
Вот пример:
from fastapi import APIRouter
import os
import threading
import asyncio
app = APIRouter()
@app.get('/sync')
def tarefa_sincrona():
print('Sync')
total = 0
for i in range(10223424*1043):
total += i
print('Sync task done')
@app.get('/async')
async def tarefa_sincrona():
print('Async task')
await asyncio.sleep(5)
print('Async task done')
< /code>
Если я сделаю два запроса - первые в конечной точке синхронизации, а вторая - в асинхронную конечную точку - почти одновременно, я ожидал, что цикл события будет заблокирован. Однако на самом деле происходит то, что два запроса выполняются «параллельно».>
Подробнее здесь: [url]https://stackoverflow.com/questions/79382645/fastapi-why-does-synchronous-code-do-not-block-the-event-loop[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия