Тёмный

Основы Asyncio 

Python Russian
Подписаться 16 тыс.
Просмотров 10 тыс.
50% 1

В продолжение беседы о конкурентости и параллельности в Python, пришла пора посмотреть на модный молодежный asyncio
Асинхронное выполнение подходит для IO-bound задач, работает ровно 1 поток
Плюсы:
+ скорость и экономия времени, вместо x + y + z = max(x, y, z)
+ управляемость
+ меньше потребление ресурсов (в сравнении с потоками)
Минусы:
- "умирает" из-за одного блокирующего вызова (!)
- не безразмерный, нужно понимать, что корутины не бесплатные
важные принципы:
1) корутина работает как генератор
2) async - явный флаг, что данная функция является асинхронной (корутиной)
3) await - явный флаг, что в это месте функция встает на паузу и дает работать другим, пока ждет свои данные
4) event loop - цикл событий, механизм, который отвечает за планирование и запуск корутин. Можно представить как
список/очередь, из которого в вечном цикле достаются и запускаются корутины
Частые ошибки:
- не использование await внутри корутины
- создание корутины, но использование ее, как функции
- использование внутри корутин синхронного(блокирующего) кода, в том числе IO
Читать:
docs.python.org/3/library/asy...
Фаулер М. "Asyncio и конкурентное программирование на Python"
Присоединяйтесь к помощи каналу, будет интересно)
✔️Бусти boosty.to/python_russian/donate
✔️Юмани 410011506612886
Будь первым везде и всегда, включай уведомления о новых выпусках 🔔
#Python #PythonRussian #Asyncio

Опубликовано:

 

24 фев 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 83   
@IlyaErokhin-uv7vx
@IlyaErokhin-uv7vx Месяц назад
Единственное видео, где автор смог понятным образом донести суть асинхронщины, к тому же прошелся ПОСТРОЧНО по коду расъяснив его в деталях, благодарю
@BaDiTaRaKaN
@BaDiTaRaKaN День назад
Наконец-то я понял, что такое асинхронное программирование. Спасибо большое
@danilfighter6179
@danilfighter6179 3 месяца назад
Очень жду вторую часть. Спасибо большое за такой информативный и самое главное - бесплатный контент. Ты лучший!
@PythonRussian
@PythonRussian 3 месяца назад
спасибо, но уточните на всякий случай о какой второй части речь?)) у меня дальше по планам мультипроцессинг и давно просят рекурсию
@danilfighter6179
@danilfighter6179 3 месяца назад
@@PythonRussian Может будет более детальный разбор 🥺🥵
@user-ed1hy3by5p
@user-ed1hy3by5p 3 месяца назад
Не, ну реально лучший. Причём с большим отрывом!
@user-buser_eto_ja
@user-buser_eto_ja 3 месяца назад
@@PythonRussian Рекурсию, да с большим нетерпением ждем!
@Nicktimes
@Nicktimes 2 месяца назад
​@@danilfighter6179что тебе здесь непонятного?автор почти целый час разжовывал материал,не понял если то заново смотри и вникай,ты тупо на автопилоте посмотрел нихера не понял и клянчишь вторую зачем та часть
@podgorniy.r
@podgorniy.r Месяц назад
Только запустил и сразу понял, что это лучшее видео на данную тему из свежих материалов!
@SemyonKalyakulin
@SemyonKalyakulin 3 месяца назад
все четко по сути. Очень наглядно. Всем рекомендую ваш канал!)
@user-oq9tu5rw9z
@user-oq9tu5rw9z 15 дней назад
Спасибо за контент! При поиске материалов по asyncio сразу нашел твое видео, но из-за непривлекательности заставки пропустил. После продолжительного чтения документации и статей на Хабре, понял, что нет понимания базы. Вернулся к твоему видео и все стало максимально понятно.
@PythonRussian
@PythonRussian 14 дней назад
ну ты чего -о книге по обложке судишь?))) да и заставку конкретно в 1 этом случае сгенерил ИИ, ты прям обидел нарождающийся скайнет =) По основам - очень хорошо, что понял и начал их осваивать, я сам в свое время забуксовал, потому что начал не с основ, а с синтаксиса, думал все очевидно.
@ProficusLets
@ProficusLets 2 месяца назад
Спасибо за такой объемный интересный и детальный гайд. Продолжай развивать канал!
@aradarbinyan312
@aradarbinyan312 Месяц назад
37:53 блин как же это в точку. У меня было ровно то что говорит автор, асинхронный телеграм бот а внутри него синхронные библиотеки. Вот прям один в один. Автору видео кстати респект за качественное видео! Это пока лучшее пояснение ассинхронисти в Python которое я видел. Продолжай в том же духе!
@otbephncb4458
@otbephncb4458 3 месяца назад
Корутина засыпает, просыпается мафия)
@photo_graf_khv
@photo_graf_khv 22 дня назад
Отличное объяснение! Благодарю!
@dilirink9222
@dilirink9222 2 месяца назад
спасибо! всегда было лень разобрать эту тему) тут за первые 20 минут прочухал как оно работает)
@alexeymatveev9031
@alexeymatveev9031 3 месяца назад
Отлично, давно ждал, спасибо!
@fragtv8163
@fragtv8163 Месяц назад
Просто гений, легенда объяснений. Я так счастлив не был давно😅
@PythonRussian
@PythonRussian Месяц назад
удивлен что видео по асинке может вызвать такую реакцию, но рад
@Mesedal
@Mesedal 3 месяца назад
Большое спасибо за понятное объяснение!
@davidbibi3138
@davidbibi3138 3 месяца назад
Спасибо за видеоурок :)
@ngbaranov
@ngbaranov Месяц назад
Очень хорошо, всё по полочкам, всё понятно
@user-ho8ve3kc4i
@user-ho8ve3kc4i Месяц назад
спасибо большое, все очень доходчиво, интересно и очень полезно.
@SashaBorandi
@SashaBorandi 3 месяца назад
Очень все разжевано, спасибо
@user-us6vw8yb9l
@user-us6vw8yb9l 3 месяца назад
Еще не смотрела, лайк поставила. Потом зайду посмотрю))
@user-im7if6ps3z
@user-im7if6ps3z 13 дней назад
Кратко и очень понятно, рекомендую!
@Tonyjusttony
@Tonyjusttony Месяц назад
Лучший! Спасибо.
@alexgreen984
@alexgreen984 2 месяца назад
Спасибо, полезно
@pLop6912
@pLop6912 8 часов назад
Огромное спасибо, появилось понимае как все это работает, но все же вопрос задам, есть библиотека PyQt5 она единственная выполняет нужное мне создание интерфейса ни одна другая его повторить не смогла но она блокирует карутины, можно ли это ка кто обойти и запустить окно без блокировки остальных карутин?
@rayrayray4653
@rayrayray4653 3 месяца назад
Четко!!!
@denoxi
@denoxi 2 месяца назад
Привет! Огромное спасибо за видео! А можно объединить многопоточность и Asyncio? Было бы здорово посмотреть твое видео с этим примером)
@PythonRussian
@PythonRussian 2 месяца назад
идея хорошая, надо подумать - сделать ли это сразу или после процессов сразу и про потоки и про процессы.
@tryhard114
@tryhard114 3 месяца назад
Охх какая тема.. Автор бросил вызов решив взяться за Asyncio на своём канале с его стилем объяснения..но я посмотрю и запишу всё!
@blackark11
@blackark11 Месяц назад
Спасибо
@user-buser_eto_ja
@user-buser_eto_ja 3 месяца назад
СПАСИБОООООО!!!
@lifestyletv139
@lifestyletv139 3 месяца назад
Красава бро
@FarofWell
@FarofWell 3 месяца назад
наконец то асинхронка
@kishiva4965
@kishiva4965 8 дней назад
Крутое видео, спасибо! Правильно ли я понимаю, что в асинке не получится перемешать синхронные функции и асинхронные? Например у меня есть 6 функций обращений к разным внешним ресурсам по апи, но вызываются они в разное время синхронными функциями, получается чтобы воспользоваться благами асинхронности, мне придётся вызывать все асинхронные функции обращений одной асинхронной main функцией разом в одном моменте, а уже потом проводить все остальные синхронные манипуляции?
@PythonRussian
@PythonRussian 8 дней назад
перемешивать не надо, асинка будет ждать полного выполнения синхронной функции, Но у асинкио есть специальные методы - запуск в отдельном потоке и в отдельном процессе, возможно это поможет вам решить вашу задачу. Или подумать о полной замене всего синхронного на асинк-варианты
@stspartak
@stspartak 3 месяца назад
The BEST!
@donatelmrlybarskiy6171
@donatelmrlybarskiy6171 7 дней назад
Пушка брат
@stevem4806
@stevem4806 2 месяца назад
Здравствуйте, спасибо за видео! Только я не понял как правильно await‘ы ставить в асинхронных функциях?
@PythonRussian
@PythonRussian 2 месяца назад
мы их ставим там, где нам нужно дождаться результата какой-либо корутины
@stevem4806
@stevem4806 2 месяца назад
@@PythonRussian понял вас, спасибо!
@quasar-lv6pp
@quasar-lv6pp 3 месяца назад
Один из крутейших русскоязычных каналов по python на ютубе! НО! (без критики, но о просьбе) Друже, сделай видос с практикой. Варианты разные: пишем чат, бот, магазин, игру в телеге...
@PythonRussian
@PythonRussian 3 месяца назад
у меня на видео то времени нет почти, практика - это сложно, мало кому интересно будет, все же со своими желаниями и планами.
@user-mobilnik
@user-mobilnik 2 месяца назад
А будет такой же прекрасный урок по multiprocessing?
@PythonRussian
@PythonRussian 2 месяца назад
будет, но попозже и не уверен, что прекрасный)
@user-nu3ot7td1j
@user-nu3ot7td1j Месяц назад
так и не поняла, почему если после await asyncio.sleep(2) я напишу следующей строчкой input(), то программа просто завершится без запроса ввода ?
@user-zb5yz9dm2f
@user-zb5yz9dm2f 28 дней назад
Потому что поток выполнения на await передаеься следующей корутине в цикле событий. Если в очереди нет других корутин, то main завершается, если вы в main не дождались выполнения корутины.
@benben-fz2es
@benben-fz2es 3 месяца назад
один момент не уяснил - если авейтить простой вызов (например, несинхронный реквест), оно ждет? или ей и увнутре тоже надо помечаться = иметь переписанную под асинкайо библиотеку. попробую вечером покатать. например - поставить обычный sleep. засада если нет - если наследовал классы из стандартных не-асинхронных, придется слегка переписывать, рефактора может и не хватить.
@PythonRussian
@PythonRussian 3 месяца назад
я большую часть вопроса вообще не понял, но ты не можешь авейтить что попало, только Awaitable объекты то есть корутины, таски и так далее, несинхронный реквест не будет авейтится -упадет ошибка.
@benben-fz2es
@benben-fz2es 3 месяца назад
@@PythonRussian именно это я и спрашивал. Корутины, использующие неасинкио айо запросы. Ошибка. Понял. Значит, приватное айо через потоки.
@benben-fz2es
@benben-fz2es 3 месяца назад
Поправь, правильно ли я понял. если очень грубо: в отличие от многопоточности, где у тебя в питоне есть свой скедулер раздавать кванты времени любому типу кода, используем почти прямые систем коллы, и полагаемся на операционку для таск свитча. То есть если авейтить *свой* код, а не неприкрытые систем коллы из асинкио, то некому скедулить, потому что операционка не умеет свитчить арбитрарные/приватные куски кода. Логично. Но, конечно, костылик такой себе - убрать свой скедулер в пользу операционки *через ТАКОЕ*. Выигрыш - в убирании оверхеда своего скедулера, проигрыш - сужение применения: только системколлы. Да и синтаксис немного напрягает: киворды - доступны, а механика за ними - только после импорта асинкио.
@benben-fz2es
@benben-fz2es 3 месяца назад
И еще раз спасибо. Твои видео - драгоценны!
@user-lo3xm2ff9w
@user-lo3xm2ff9w 3 месяца назад
мужик!!!
@DeliriumOFF
@DeliriumOFF 3 месяца назад
c файлами тоже есть асинхронная работа?
@PythonRussian
@PythonRussian 3 месяца назад
на самом деле там есть сложности, по разному реализовано на разных ОС, потому скорее с файлами придется работать используя потоки, асинкио умеет запускать в отдельном потоку блокирующую задачу не мешая текущему циклу событий
@non5309
@non5309 3 месяца назад
есть
@paulkarkarin466
@paulkarkarin466 3 месяца назад
Можно было Semaphore упомянуть. Чтобы люди понимали, что корутина не резиновая. А многие API вообще не любят когда их реквестами досят по 100 запросов в секунду. Вернут 500 ошибку и будут сидеть. Вообще, скорее это и есть слабое место: ограничение серверов на забор/вставку данных. Хотел спросить про мультитрединг+асинхронность: можно ли их как-то совместить, чтобы по максимуму использовать возможности железа (в условиях питона)? На самом деле это просто праздный вопрос из любопытства, учитывая ограничения, о которых я написал в начале.
@sio8730
@sio8730 3 месяца назад
мультитрединг+асинхронность не даст по максимуму задействовать железо (ядра процессора), ответ в документации CPython (реализации интерпретатора на Си), если кратко то виной этому GIL. А вот связка мультипроцессинг+асинхронность позволит при грамотном построении программы очень неплохо нагрузить железо
@PythonRussian
@PythonRussian 3 месяца назад
чтобы железо по максимуму в дело пустить, это надо другой язык =) вот с питона 13 говорят ГИЛ уберут(опционально), соответственно даже простой многопоточки должно хватать, но это надо будет смотреть как оно в реале будет и я сомневаюсь что прямо все ядра процессора задействует.
@user-nz1nc1cu6i
@user-nz1nc1cu6i 3 месяца назад
ещё бы разбор асинхронщины в django 5
@PythonRussian
@PythonRussian 3 месяца назад
увы, этого точно не будет, я не использую джанго
@Sizt
@Sizt Месяц назад
Не очень понятно, как получить выигрыш за счет asyncio, используя только стандартную библиотеку. На 0:38 обещали рассказать принцип работы, а он так и не был объяснен в видео :( Очень хотелось бы подобный пример.
@user-zb5yz9dm2f
@user-zb5yz9dm2f 28 дней назад
Так в примерах и используется стандартная библиотека. Пересмотрите первую половину. В стандартной библиотеке есть синхронные функции и асинхронные. Как пример, пакеты asyncio, aiohttp. В корутинах надо с await использовать асинхронные.
@Sizt
@Sizt 27 дней назад
aiohttp не стандартная.
@sergeyvereshaghin2330
@sergeyvereshaghin2330 3 месяца назад
Прочитал сначала как: разбор arduino)) думаю, что за приколы 😂
@tenebris8800
@tenebris8800 Месяц назад
Кто знает как два лайка поставить???
@crazzy6903
@crazzy6903 6 дней назад
Такое ощущение как будто рассказывается для дегенератов. Повторяется что то очевидно по сто раз. Терминология по типу замораживатель времени вообще меня убила Спасибо!
@PythonRussian
@PythonRussian 6 дней назад
а главное -это работает )))
@user-zx6fq1ig4h
@user-zx6fq1ig4h Месяц назад
Очень плохое объяснение асинхронности. Куча воды, мутные термины... Советую поискать другие источники, их полно!
@eugenybobylev5438
@eugenybobylev5438 12 дней назад
Сколько людей, только мнений. Мне не зашло, очень мутное объяснение
@PythonRussian
@PythonRussian 12 дней назад
это нормально что не зашло, для того и есть инет - чтобы каждый находил то, что ему нравится
@Hi-gjgruncdun
@Hi-gjgruncdun Месяц назад
Лайк подписка, очень доходчиво, спасибо
@mslq
@mslq 3 месяца назад
tkinter и прочие GUI ведь уже и есть асинхронка, или как она там называется - событийное выполнение, даже root.mainloop такой же. На ATmega ещё пишу на асме, у меня там своя ось, тоже все таймеры, и прочие элементы все в асинхронке работают, гарантированный проход всей программы 1 ms.
@PythonRussian
@PythonRussian 3 месяца назад
не готов по гуи ответить, у них могут быть и несколько потоков, но с той же логикой - главный поток обрабатывает отрисовку и клики, а в потоках-демонах все обрабатывается не замедляя главный и не мешая ему. Но опять же -не силен, не занимался, могу жестоко ошибиться.
@Nicktimes
@Nicktimes 2 месяца назад
Вопрос в момент усыпления корутины,когда ивент отлажывает эту корутину в список,и переключается на другую,Запросы в бд или на сайт выполняется уже?раз Ивент понял что в этой корутине пришел ответ от Бд либо от сайта,чутка поясните,эти запросы и ответы приходят в момент когда корутину убрали спать?
@PythonRussian
@PythonRussian 2 месяца назад
я просто не хотел усложнять объяснение, но вопрос верный задаете. По сути в момент авейта в ивент луп на самый верх кладется как раз корутина которую ждем(например запрос к сайту) она сразу начинает выполняться. И уже она (обычно это какая то библиотека типа аиохттп под капотом) делает запрос и так как ответ нужно ждать тоже объявляет авейт до момента прихода ответа. От нас это обычно скрыто особенностями реализации библиотек, потому что мы пользователи этих библиотек и нам не очень важно что конкретно они делают, главное понимать как с ними работать (авейты и т.п.). Но если вы сами хотите писать такие библиотеки то тут конечно без погружение в детали асинкио не обойтись.
@Nicktimes
@Nicktimes 2 месяца назад
@@PythonRussian спасибо за хорошее разьяснение...
@mslq
@mslq 3 месяца назад
Я всегда наступаю на грабли и что под капотом и на капоте, и много раз повторять надо чтобы усвоить.
Далее
This duo #UFC302
00:13
Просмотров 494 тыс.
Dancing makes everything better 🕺🏼
00:16
Просмотров 5 млн
ASYNCIO НА ПРАКТИЧЕСКОМ ПРИМЕРЕ
22:44
Основы многопоточности в Python
58:46