import asyncio: Learn Python's AsyncIO #1 - The Async Ecosystem

Поделиться
HTML-код
  • Опубликовано: 16 июл 2024
  • This series of videos introduces AsyncIO to Python programmers who haven't used it yet. The first episode is a high-level view on the async ecosystem. We cover:
    - why you'd want to use asynchronous code at all;
    - how latency drives the user experience;
    - what the difference between concurrency and parallelism is;
    - some of the problems you can encounter with threads, and with threads in Python in particular;
    - a short story about select, the OG of async calls; and
    - the history of asynchronous programming in Python that led to AsyncIO.
  • НаукаНаука

Комментарии • 116

  • @ekkamailax
    @ekkamailax 3 года назад +13

    You're one of the few people on the planet who understanding the psychology of explaining things effectively. Great video.

  • @PawlTV
    @PawlTV 3 года назад +72

    This series is the most complete AsyncIO tutorial on RUclips. Massive thumbs up! :)

    • @luxetim1541
      @luxetim1541 2 года назад +1

      :( why it is hard

    • @itsfoss5268
      @itsfoss5268 10 месяцев назад

      @@luxetim1541 😅

    • @cstechnique
      @cstechnique 9 месяцев назад +1

      Since the moment he mentioned 'select sys call,' I didn't understand what he was saying. It's specialized knowledge about Linux and networking, which I'm not familiar with. Perhaps there should be a course that introduces async for the majority of learners, without such academic knowledge

  • @senpos
    @senpos 4 года назад +24

    Loving it! Especially the part about using blocking stuff in my async codebase. Sometimes it is not as convenient as it could be. Also, errors handling and debugging usually missed in such series, thanks for not skipping it!

  • @senses0
    @senses0 4 года назад +43

    This is very well thought out and provides context, history and answers the WHYs before taking a shortcut to ide/code editor. Highly recommended for anyone interested in understanding crucial concepts behind the asyncio implementation.
    Looking forward to the rest of the episodes!

    • @cstechnique
      @cstechnique 9 месяцев назад

      Your teaching style is not really good and not intuitive. Going through a series of PEPs and just briefly introducing them, how can viewers understand what you are saying? This is a lecture, not a movie. Viewers need to watch attentively and carefully to understand, unlike a movie where viewers can watch or not, or fast forward to another part, and viewers don't get a headache from watching a movie.

  • @victornikolov537
    @victornikolov537 9 месяцев назад +10

    I am putting this on pause at 38:56 to comment here. I've never thought it would be so interesting to listen about all the history and the path that led to Asycnio.
    Thank you.

  • @sirius7584
    @sirius7584 2 года назад +13

    19:58 Gilectomy -> overcoming the limitation of GIL is not easy.
    23:13 the goal of asyncio -> maximize the usage of a single thread.
    29:15 event loop -> Select syscall as a solution to waste of CPU or lag

    • @cstechnique
      @cstechnique 9 месяцев назад +1

      Since the moment he mentioned 'select sys call,' I didn't understand what he was saying. It's specialized knowledge about Linux and networking, which I'm not familiar with. Perhaps there should be a course that introduces async for the majority of learners, without such academic knowledge

    • @munteanionut3993
      @munteanionut3993 2 месяца назад

      thanks a lot for the clarifications!

  • @AyushDhingra
    @AyushDhingra 24 дня назад

    I wish you had (or would) create more such amazing in-depth playlists. Teachers like you make us fall in love with programming again and again. Thank you so much!!

  • @IvanAndreScheel
    @IvanAndreScheel 4 года назад +10

    Came here after listening to you on the Real Python Podcast. This is some amazing insight into Python's AsyncIO. Keep it up!

  • @dhiegorp
    @dhiegorp 3 года назад

    Congrats for this video! The most complete I`ve ever seen, specially the historic part. Knowing which concepts and early ideas participated in the creation/evolution of asyncio and its peers was great. Definetely I`ll check the rest of the series.

  • @danielrosenwald
    @danielrosenwald 3 года назад +4

    Explained things so well! Loved hearing the history of asyncio to contextualize it's current implementation. To say you did your homework would be an understatement! Thanks again

  • @illiaavdiienko8177
    @illiaavdiienko8177 4 года назад +11

    love it! keep doing tutorials, they are really nice

  • @ReubenCleetus
    @ReubenCleetus 4 года назад +1

    A very thorough discussion! So informative, and the speaker is excellent.

  • @ruijungao
    @ruijungao 3 года назад

    Amazing detailed introduction to the history of asyncio and so much stuff about the ecosystem of coroutine in Python, loving it and thanks!

  • @kobooa
    @kobooa 3 года назад +1

    Jestem absolutnie zachwycony twoim tłumaczeniem :D Miło słyszeć, że ktoś to tak świetnie tłumaczy - domyślam się, że nie tylko ja to mówię, ale i tak zostawiam komentarz dla zasięgu :P

  • @andreostrufka69
    @andreostrufka69 4 года назад

    Hello. Your video is awesome! I am from Brazil, I started working with AsyncIO and python a few weeks ago, and your content is being so helpful. I hope you keep doing that. Congratulations!

  • @Meritumas
    @Meritumas 4 года назад

    Great tutorial! Thank you, Lukasz for taking the time and explaining asyncio.

  • @wellspokenman81
    @wellspokenman81 3 года назад

    this is amazing work. I've bounced off a half dozen asyncio tutorials but it's finally, finally starting to click for me. rlogin was my bathtub moment - many thanks.

  • @keshavsingh489
    @keshavsingh489 Год назад +1

    Thanks a lot for this video! Watched a lot of asyncio and no one had explained it as well as you did. Please keep sharing !!

  • @Factory400
    @Factory400 3 года назад

    Wow! This is a gem....super impressed with the depth. Love this.

  • @paulmarkus4917
    @paulmarkus4917 2 года назад +1

    I have been trying to learn AsyncIO in Python for a while now and this is by far the best (clear, concise, deep) resource I have found. Massive thanks to Lukasz and Edge DB team for arranging this!

  • @hmx7497
    @hmx7497 3 года назад +1

    讲的太好了,找了很久有关python asyncio相关的高级知识,现在终于看到了,谢谢你无私的分享

  • @recordable542
    @recordable542 9 месяцев назад

    This is the BEST asyncio video I have watched so far! I'm bound to applaud

  • @btel
    @btel 8 месяцев назад

    Great lecture series. After spending hours online and looking at asyncio implementation, I am finally starting to get it. Thank you so much!

  • @minyakonga8897
    @minyakonga8897 Год назад +1

    Awesome introduction, I need to check all these PEPs and libraries, learned a lot. Thanks EdgeDB.

  • @anibalismaelfermandois6943
    @anibalismaelfermandois6943 4 месяца назад

    This is a super super good video. I didn't expect such a comprehensive take on async await.

  • @seydoudia7828
    @seydoudia7828 4 года назад

    This is so excellent! I will borrow the bartender analogy to explain concurrency from now on. Subscribed and thank you!

  • @hubertzelek7780
    @hubertzelek7780 2 года назад

    Łukasz, this is some very, very, very in detail history knowledge which I'm deeply grateful to you! Thanks for your time and effort. I'm going to continue on rest of the movies!
    Buy this man a beer!

  • @LukVerhelst
    @LukVerhelst Год назад

    This explanation is the best I ever came across on the subject of asynchronous handling ❤

  • @Penfold__
    @Penfold__ 4 месяца назад

    Mate thank you for putting these together, you’re a great teacher.

  • @rogerbrinkmann
    @rogerbrinkmann 4 года назад

    Great content, exactly what I was looking for!

  • @pietraderdetective8953
    @pietraderdetective8953 9 месяцев назад

    OMG your explanation is one of the most comprehensive yet relaxed hence easy to understand.
    Liked and subscribed!
    You have an amazing channel Sir!

  • @fibromyalgie-traitement2600
    @fibromyalgie-traitement2600 3 года назад

    Amazing piece of content. Thank you so much for such fantastic quality of information. Special mention for performing the donkey from shrek's "are we there yet" !

  • @tourdesource
    @tourdesource Год назад

    A true masterclass. Thank you!

  • @slonbeskonechen8310
    @slonbeskonechen8310 2 года назад +1

    simple and circumstantially! Thank you!

  • @atmospheric_b
    @atmospheric_b 3 года назад

    i thought i will listen to core details in asyncio but man this is SO interesting i should watch the whole playlist! Thank you very much

  • @laysauchoa7557
    @laysauchoa7557 Год назад

    Thanks for sharing your knowledge and explaining this hard to grab concepts with such elegance 👏

  • @naeemkhoshnevis
    @naeemkhoshnevis 4 года назад

    Very well prepared and presented. Thanks.

  • @getitjob
    @getitjob 4 года назад

    Łukasz big Thanks :). Your knowledge is huge and you are really good as you-tuber. I have tried this and it is no easy.

  • @asim-gandu-phenchod
    @asim-gandu-phenchod 4 года назад

    Love to see a detailed series on async

  • @EmrahBilbay
    @EmrahBilbay 4 года назад

    Great stuff! Love it

  • @jesavius
    @jesavius 4 года назад

    Learning the fundamentals of Asyncio and building an app with Starlette and EdgeDB!? This will be the best RUclips series for Python devs in the history of RUclips Videos about Python!!!

  • @anuragshrestha7711
    @anuragshrestha7711 3 года назад

    You should make more videos. Really nice examples and thoughtful.

  • @edboythinks
    @edboythinks 2 года назад

    i never thought, as someone who has been learning python since 8 weeks ago, that i would have such an intimate knowledge of a module before i ever knew how to implement it

  • @KulvinderSingh-pm7cr
    @KulvinderSingh-pm7cr 4 года назад

    Splendid job 🤘

  • @pyderator
    @pyderator 4 года назад

    Great Explanation !!

  • @imaurer
    @imaurer 4 года назад +1

    Thanks Łukasz for these videos and for the black formatter.

  • @amidfallen
    @amidfallen 3 года назад

    wow, thank you! I hope I will obtain enough knowledge to implement Asyncio in my Flask project.

  • @AurelioCosta
    @AurelioCosta 3 года назад

    Really nice explanation. Thanks

  • @BaselHamadeh
    @BaselHamadeh 4 года назад

    This is awesome. Thanks alot

  • @PythBuster
    @PythBuster 3 года назад

    Amazing, thank you so much! :)

  • @leaoaugusto
    @leaoaugusto Месяц назад

    wow.. awesome content! thank you

  • @y.bibaev
    @y.bibaev 4 года назад

    Thanks. Very interesting

  • @paffcio4050
    @paffcio4050 4 года назад

    When you talk about the event loop you often bring up the picture with those callbacks. It was always rather confusing to me. I finally understood what did you mean by it. Thanks

  • @rafaelacioly3252
    @rafaelacioly3252 4 года назад

    Super nice!

  • @mohammadyahya78
    @mohammadyahya78 Год назад +1

    Wow! Thank you. I wish if you had a book about threadin in Python.

  • @hosseinsokhandan450
    @hosseinsokhandan450 3 года назад

    That was precious.

  • @foxdeveloper7707
    @foxdeveloper7707 5 месяцев назад

    Crisp and detailed contents with nice presentation. :) --> and going to try edge DB

  • @francescolucantoni3243
    @francescolucantoni3243 4 года назад

    AWESOME!

  • @shrishtychandra2003
    @shrishtychandra2003 3 года назад

    Great video.. Seriously

  • @JayJay-ki4mi
    @JayJay-ki4mi 9 месяцев назад

    Fellow ex. FB employee too. I worked in security. Great course to get me up to speed with this library.

  • @tarassavchenko2317
    @tarassavchenko2317 3 года назад

    really interesting tuts

  • @kobooa
    @kobooa 3 года назад

    Możliwe, że i ten komentarz jest dla zasięgu :P, ale w tym powiem, że też miło w końcu rozumieć skąd to wszystko się wzięło :D

  • @pldvs
    @pldvs 4 месяца назад

    Nice. Thanks.

  • @alexezio3352
    @alexezio3352 3 года назад

    Great Vedio!!!!!!!!!!

  • @laguitte
    @laguitte 4 года назад +2

    Very nice start to what promises to be a very interesting series.
    One thing I'm not sure about: one hand you say "the GIL is what makes python fast" and you work on asyncio to make it even faster; on the other hand I see Google starting the S4TF team to push for ML to be written in Swift because "python is slow". Who is right ?

    • @EdgeDB
      @EdgeDB  4 года назад +1

      Good question! Python is both a programming language that you see in your text editor, as well as a runtime that executes your program. It is impossible to think about Python just looking at the source code without thinking how it behaves - or can behave - at runtime.
      An important feature of Python is that nothing is private, everything is mutable and introspectable. Plenty of features of Python rely on this design. This puts some constraints on how fast native Python can run, for example due to very widespread usage of dictionaries, duck typing, and so on.
      When we're saying that the GIL is what makes Python fast, we mean that without the GIL the particular design that CPython is an implementation of, would be less efficient without a single global interpreter lock.
      Other programming languages have different sets of guarantees and features, sometimes very specifically chosen to allow better native performance. While Swift isn't particularly interesting in this space, we at EdgeDB are quite excited about Rust for systems programming. Our database server already includes Rust code for some performance-critical bits (which in the old times would typically be handled by writing a C extension).

  • @fringefringe7282
    @fringefringe7282 2 года назад

    Piekna sprawa.

  • @busydying
    @busydying 4 года назад

    Maybe it worth to cover ASGI as well before moving to Starlette, it would be consistent with the bottom to top approach you've chosen. I can't wait for the EdgeDB section though :)

  • @Alexus736
    @Alexus736 3 года назад

    Very good

  • @Fran-kc2gu
    @Fran-kc2gu 2 года назад

    I just finished the podcast on Real Python came here for more :D

  • @borisrunakov1662
    @borisrunakov1662 3 года назад

    Thank you for the video! I got a bit confused at about 12:45 where you explain who catches the error when adding to the dictionary and what thread propagates it. Could you please elaborate? Thanks in advance !

  • @bartek9167
    @bartek9167 3 года назад

    Just out of curiousity, how many times were you recording the part with 6 seconds sleep and adding another variable? :D

  • @dewashyadubey9829
    @dewashyadubey9829 7 месяцев назад

    Correct me if I'm wrong. I have an example for deadlock, "You are trying to find job to gain experience, but need experiance to get a job"

  • @pahehepaa4182
    @pahehepaa4182 3 года назад +2

    It's been more than 5 months since the last video. Will you add the remaining parts or will we be left hanging midway ?
    :/

  • @aaronjiang9478
    @aaronjiang9478 7 месяцев назад

    Are there any articles or blogs that accompany the videos?

  • @jsr7599
    @jsr7599 3 года назад

    The video where it clicked, thanks.

  • @uploadvoice
    @uploadvoice 3 года назад

    Would it be as efficient as node's main loop ?

  • @random_act
    @random_act 3 года назад

    nice

  • @DannyZaharia
    @DannyZaharia 4 года назад

    Great series! when's the next video coming up?

    • @EdgeDB
      @EdgeDB  4 года назад +1

      We're uploading it right now. We'll be targeting to release at least one new episode per week.

  • @cstechnique
    @cstechnique 9 месяцев назад +1

    Since the moment he mentioned 'select sys call,' I didn't understand what he was saying. It's specialized knowledge about Linux and networking, which I'm not familiar with. Perhaps there should be a course that introduces async for the majority of learners, without such academic knowledge

  • @human-011
    @human-011 3 года назад

    My doubt is, how that bartender (25:04) goes back to previous customers? please reply

  • @akhil3365
    @akhil3365 3 года назад

    what is the difference between qrequests and asyncio

  • @bhuller0164
    @bhuller0164 Год назад

    Sometimes explaining just the main point is good rather than giving overwhelming information.

  • @bertproeme4535
    @bertproeme4535 3 года назад +1

    What causes this? --> RuntimeError: asyncio.run() cannot be called from a running event loop

  • @user-fz9zg5gt4c
    @user-fz9zg5gt4c Год назад

    спасибо яндекс что я могу смотреть это видео на русском
    но главное спасибо автору видео :)

  • @berryk.4174
    @berryk.4174 2 года назад

    Exactly wait I was looking for, after watching a couple of other tutorials on async(io) (around 30~45m each) I felt like they all barely touched base and put code on the screen way to fast for me to grasp all concepts.

    • @berryk.4174
      @berryk.4174 2 года назад

      actually, just watched this first episode and am really pleased with the content. I'm going to watch the rest tomorrow.

  • @Busan2
    @Busan2 3 года назад

    23:10 There's one more thing!

  • @ceoofthen-word8849
    @ceoofthen-word8849 2 года назад +1

    "Mr White, I'm gonna teach you asyncio"

  • @mahdisecurity1700
    @mahdisecurity1700 3 года назад

    hi this is a great video but if with code programming is better and more example and write your example such as senario.
    god willing

  • @voilin
    @voilin 2 года назад

    It would have been most amazing python async series if only black resorted to single quotes

  • @itsfoss5268
    @itsfoss5268 10 месяцев назад

    Dude, you even mentioned K8S and Fargate in the introductory series. I gues this is not meant for someone who is fairly new to these things huh?

  • @rochakgupta6116
    @rochakgupta6116 Год назад +1

    I was looking for copper and found gold

  • @tamos2006
    @tamos2006 3 года назад +1

    consider changing ur career to instructor, everything is just well exaplined.

  • @ehsanreghabi
    @ehsanreghabi Год назад +1

    Who's here from real python podcast?

  • @luscasleo
    @luscasleo 2 месяца назад

    I feel bad for the bartender

  • @zofiagaming4281
    @zofiagaming4281 3 года назад

    You have lost me on bartender analogy Łukasz ;) I guess you should see what real bartenders do in a busy place!

  • @adithp1051
    @adithp1051 6 месяцев назад

    reading off the script

  • @notAvn
    @notAvn 2 года назад

    until minute 31 i liked the video but than u went way too indepth into history idc about

  • @RevFried
    @RevFried 4 года назад +6

    this guy is pretty average looking I guess

    • @llanga
      @llanga 4 года назад +3

      Awww, that's the nicest thing anyone has ever said to me ♥️

    • @cstechnique
      @cstechnique 9 месяцев назад

      Hi Langa, Since the moment he mentioned 'select sys call,' I didn't understand what he was saying. It's specialized knowledge about Linux and networking, which I'm not familiar with. Perhaps there should be a course that introduces async for the majority of learners, without such academic knowledge
      @@llanga

    • @cstechnique
      @cstechnique 9 месяцев назад

      Your teaching style is not really good and not intuitive. Going through a series of PEPs and just briefly introducing them, how can viewers understand what you are saying? This is a lecture, not a movie. Viewers need to watch attentively and carefully to understand, unlike a movie where viewers can watch or not, or fast forward to another part, and viewers don't get a headache from watching a movie.
      @@llanga

  • @cstechnique
    @cstechnique 9 месяцев назад +2

    Your teaching style is not really good and not intuitive. Going through a series of PEPs and just briefly introducing them, how can viewers understand what you are saying? This is a lecture, not a movie. Viewers need to watch attentively and carefully to understand, unlike a movie where viewers can watch or not, or fast forward to another part, and viewers don't get a headache from watching a movie.

  • @rajatsharma6137
    @rajatsharma6137 2 года назад

    not very useful for me....felt like you are reading from a book...maybe good for advanced python programmers..