Introduction To The Actor Paradigm In Golang

Поделиться
HTML-код
  • Опубликовано: 30 янв 2025

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

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

    ► Join my Discord community for free education 👉 discord.com/invite/bDy8t4b3Rz
    ► Pre order (get 30% off) my Golang course 👉 fulltimegodev.com
    ► Become a Patreon for exclusive tutorials 👉 www.patreon.com/anthonygg_
    Thanks for watching

  • @razvan2693
    @razvan2693 Год назад +5

    You are doing a great job Anthony ! Thank you for your time and availability of sharing this information !

  • @anshkumargarhewal8582
    @anshkumargarhewal8582 Год назад +4

    Kudos for 10k Anthony 🎉

  • @farzadmf
    @farzadmf Год назад +10

    Althought you've done a great job for the framework, I was hoping to see the underlying concepts that the framework is based on ("the actor paradigm" and what it is)
    Thank you for the video anyway

  • @lawrencekatuva8735
    @lawrencekatuva8735 Год назад +2

    Am working on a payment gateway and am consdering golang only if I'll get a good actor model implementation. How can I tie any actor to reference which I can use to access it later in a diffrent context.

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

      You have the PID when spawning one. Use that PID.

  • @simonced
    @simonced Год назад +3

    in vim, you can keep some lines space at top and bottom by setting the option "scroll offset" to a value like 5.
    example: ":set scrolloff=5"

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

      also type zz for centering the line in the screen

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

      @@peterszarvas94 every time i learn a new trick in vim i get a little burst of joy

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

      In my neovim v0.10, scrolloff doesn't seem to work anymore for this purpose.
      But you can also use ctrl+e/ctrl+y to scroll line by line. You can also use zz to center vertically the line the cursor is on, zb to move the line the cursor is on to the [b]ottom of the screen, and zt for the [t]op. The z* command also respect scrolloff

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

    I really wish you take on more TDD design so I know how to test it. I love to start with testing because tests are needed no matter what, and they are harder to write if you never had tests in mind and realize a lot of refactoring has to happen to just make it testable

  • @yafpv
    @yafpv Год назад +5

    What's difference between using framework and using native channels?

  • @eswarnichtsmehrfrei
    @eswarnichtsmehrfrei Год назад +3

    you are best actor

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

    This man is a beast

  • @skinniepuppie
    @skinniepuppie Год назад +9

    15:28 Instead of adding newlines at the end of the file to center things in VIM. Just hit “z” twice.

    • @anthonygg_
      @anthonygg_  Год назад +6

      Oof, thanks my man! Life saving info. ❤️

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

    非常棒的视频,我很喜欢这种教学风格!

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

    Anthony you’re a homie

  • @chudchadanstud
    @chudchadanstud 7 месяцев назад +1

    instead of using switch cases why not take advantage of state pattern and turn all those cases into objects? You can just send an object with a run method and when it's dequeued from the inbox we call the run method?

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

      Well, hows that going to work over the wire?

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

      Locally that would work great

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

      @@anthonygg_ In C/C++ you would use ABIs (Application Binary Interfaces). Not sure about Go, doesn't't Go have compiled binaries designed to interop?
      Your destination could simply have this binary as some form of contract.
      Another method is to have a TCP actor do all that.
      But you make a good point either way. Sometimes a simple solution is best.

  • @pryamcem
    @pryamcem Год назад +5

    finaly, VIM!!!

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

      Sorry I let you down. Im back.

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

      If possible can you publish your Vim setup video or if a doc which we can follow?

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

    Thanks for the video! What plugins do you use for autocomplete and errors colored?

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

    In terms of usage, this solution is a bit closer to an async queue system like rabbitmq, but the nice trick is that holywood just spawns a new process instead of communicating over the network, and on the other hand, there is no way to send to the consumer of another team, for example. Am I right? Thanks for the video

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

      You mean over the network?

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

      @@anthonygg_ I mean communication is between golang and OS instead of AMQP or other network protocol

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

    Does it even make sense to call `e.Send` in a goroutine? Since it's only sending a message and not actually handling it, right?

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

      Correct doesnt make sense, but just want to show the safeness of it in case you find a usecase to actually do it in a goroutine

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

    So, is it a PUB-SUB system like redis or kafka?

  • @rmkohlman
    @rmkohlman 11 месяцев назад

    Awesome

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

    i purchase the course but why there is no content

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

      The content is gradually coming over the month of april. By the end of april all will be available for your lifetime

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

      Join the discord I will add you to the course channel

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

    what colour scheme is that please?

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

      Gruvbox

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

      @@anthonygg_ sorry to ask again, but do you have a link to it, as the normal gruvbox looks a lot different :(

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

    what is the difference between using (traditional locks , channels) and this actor? from my perspective its only handling race conditions, please correct my understanding here

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

    Thankx for your videos, they are amazig! +1 sub from me

  • @atticus_foust
    @atticus_foust Год назад +2

    You should make a 2d game with this use case! If you have time**

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

    dope

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

    helloworld example with send worked - trying the code-along version again.

  • @dranon0o
    @dranon0o Год назад +3

    So basically, we're doing a an IPC (spawning a process and communicate) + a reducer based on type :p
    Pretty nice

  • @definitelynotrohan
    @definitelynotrohan Год назад +3

    yay vim diesel

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

      LMAO! This is it. That quote is mine now. Thanks buddy

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

    At this point the SetState message is not working for me at all with exactly your code.
    Will erase the whole project and try again.

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

    It would be better if you showed the native implementation and not some wrapper around it.
    Although I really like this pattern, I found out that some less experienced developers find it confusing.
    Another point, instead of sending objects, you can pass down behavior (functions) following the "Don't communicate by sharing memory, share memory by communicating." proverb.
    Also, being a blazingly fast is an outright lie. It is 10x times faster comparing to just having a struct with a receiver that does use a mutex in order to ensure thread safety

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

      it is still faster though, right? go is blazingly fast itself, i dont see that as a lie

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

    routines leak when testing the example tcpserver....

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

      Doesnt matter, its an example not a copy paste thing. Its an example to give you an idea. And if you want, make a pr and fix

  • @mzerone-g6m
    @mzerone-g6m Год назад

    The next episode make go work on beam 😂

  • @fabricioaraujo7642
    @fabricioaraujo7642 Год назад +2

    Golang basically is a python who scales better 😅😊

  • @larrasket
    @larrasket Год назад +2

    Now try Emacs

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

    anthony I would be tempted to sign up to fulltimegodev is it were a reasonable monthly fee.

  • @mzerone-g6m
    @mzerone-g6m Год назад +1

    Elixir - erlang