@zlodiak

Как asyncio распараллеливает задачи?

Допустим, что при помощи модуля asyncio выполняются 3 http-запроса.

import asyncio
import aiohttp

urls = ['http://www.google.com', 'http://www.yandex.ru', 'http://www.python.org']

async def call_url(url):
    print('Starting {}'.format(url))
    response = await aiohttp.get(url)
    data = await response.text()
    print('{}: {} bytes: {}'.format(url, len(data), data))
    return data

futures = [call_url(url) for url in urls]

loop = asyncio.get_event_loop()
loop.run_until_complete(asyncio.wait(futures))


Скажите пожалуйста, правильно ли я понимаю происходящее:
  • 1. эвент луп модуля asyncio принимает три функции
  • 2. каждую из них помещает в отдельный поток
  • 3. каждую из них в отдельном потоке преобразует в корутин
  • 4. который возвращает результат после получения данных черех http
  • 5. но пока эти данные не получены, GIL переключает эти потоки через каждые 0.005 сек
  • 6. таким образом полученные даные будут выводиться в порядке завершения http-запросов(чем раньше в каком-либо корутине успешно отработает http-запрос, тем раньше его результаты будут выведены на экран)
  • Вопрос задан
  • 222 просмотра
Решения вопроса 1
sergey-gornostaev
@sergey-gornostaev Куратор тега Python
Седой и строгий
каждую из них помещает в отдельный поток

Нет, поток один. В этом-то и весь смысл асинхронности.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы