Nix explained from the ground up

Поділитися
Вставка

КОМЕНТАРІ • 178

  • @zyansheep
    @zyansheep 2 місяці тому +444

    I sure do love it when a random yt channel with under 1k subs and a celeste speedrun posts an in-depth technical video explaining a complicated subject intuitively!

    • @vikingthedude
      @vikingthedude 2 місяці тому +7

      I think this is surma from google! Hes one of the hosts of the http 404 podcast. Jake archibald is another. Looking forward to his videos

    • @CoDEmanX47
      @CoDEmanX47 2 місяці тому +8

      ​@@vikingthedude It's HTTP 203 but yeah

    • @shamsartem
      @shamsartem Місяць тому

      @@vikingthedude also they both work at Shopify nowadays

    • @abiiranathan
      @abiiranathan Місяць тому +4

      He's not a random UA-camr! Trust me

    • @MadhavaVishnubhatla
      @MadhavaVishnubhatla Місяць тому

      ​@@vikingthedudeqq

  • @badluckprophet9103
    @badluckprophet9103 2 місяці тому +41

    Always love a "I made the video I wish I'd had." Thanks for putting this together, it's very well done.

  • @Cammymoop
    @Cammymoop Місяць тому +30

    This is very helpful, Nix needs more material that helps us understand the "Why", more stuff like this basically

  • @alexpage8085
    @alexpage8085 2 місяці тому +39

    Learned a ton from this video Surma. Thanks for summarising all of this!

  • @shvmoz
    @shvmoz 2 місяці тому +32

    Have been digging into nix/h-m over the last few weeks, awesome to have the algorithm send you to me pal!

    • @dassurma
      @dassurma  2 місяці тому +5

      Flattered that you spent your time on my vid :D
      h-m has been a game changer for me. It’s like NixOS with having to give up your normal OS. The weirdest corners for me so far have been to not be able to quickly edit my config files and having to do a special dance for nvm, rustup and similar tools.

    • @TheSast
      @TheSast 2 місяці тому +2

      ​@@dassurma if you don't use configure those directly with nix, but simply use home-manager to place them in the appropriate location, you can use home-manager to symlink them instead, allowing for rapid iteration. You can then turn that on or off with a custom option.

    • @opheon
      @opheon 2 місяці тому +1

      ​@@TheSastif the files in the appropriate location are manager by h-m, wouldn't you need to rebuild with every change?

  • @TotallyURGrandpa
    @TotallyURGrandpa 2 місяці тому +23

    Antichamber, Celeste, and now Nix. This guy knows ball.

  • @kugurerdem
    @kugurerdem 21 день тому

    One of the best videos explaining how Nix works under the hood. Wish there was such a video when I first started using it.

  • @pederpbsds
    @pederpbsds 2 місяці тому +5

    A good balance between handwaving nitpick details and drilling down into how it all comes together!

  • @arnaudbarre6006
    @arnaudbarre6006 2 місяці тому +36

    I loved the content, the tempo and the story: the end result is a consequence of logic steps, not something you take for granted. I just found that the music was a bit too loud.

    • @dassurma
      @dassurma  2 місяці тому +6

      Thanks for the kind words. You are not the first person to point that out. I’ll keep that in mind for next time :D

    • @plebiannn
      @plebiannn Місяць тому +3

      If you could upload without the music I would use it as a default for explaining nix

  • @bjeanes
    @bjeanes 2 місяці тому +11

    Excellent video. I'll be sharing this one when people ask me to explain Nix.

  • @an_imminence
    @an_imminence 2 місяці тому +3

    Most videos start where you ended. I felt like there had to be something simpler underlying all of this, and there is! Thank you so much for this. You actually explained Nix. By going through the whole math, only to then, afterwards!, show the shortcut.

    • @dassurma
      @dassurma  2 місяці тому +1

      Thank you for the kind words. Means a lot.

  • @tyler...
    @tyler... 2 місяці тому +3

    This is such a great video! I've never really understood the reasoning behind Nix until now, let alone how it works. Saving this one to my "most important videos" playlist

  • @sarahclark9256
    @sarahclark9256 Місяць тому +1

    Excellent as always! Good to hear your voice again.
    I’ve been running nixos for a couple of years and contribute to nixpkgs.

  • @tejing2001
    @tejing2001 2 місяці тому +51

    I like how you presented this. Building up from the basics without getting too bogged down in the details. I do have a few notes, though:
    8:49 This is actually (unfortunately) not the case. Antiquotes of path types do expand to a nix store path, but builtins.toString actually returns the non-store path as a string. I consider this broken behavior, and have argued that it should be changed, but it is the current behavior. As a rule, just never use toString on a path-type. If you think you need to, then you're probably mixing eval time and run time in a way that will come back to bite you at some point. Also, it isn't exactly when a path-type is evaluated that it gets copied to the nix store (in particular, if you import a path type, it needn't be copied, and isn't), but I'm pretty much fine with glossing over that.
    13:07 Yes, you did a bad thing, but perhaps more importantly, on linux, this build would have completely failed because there, builds are run inside a container without access to the host filesystem at all. Might have been good to mention.
    21:12 You did a subtle bad thing here, by overriding phases without calling the pre and post hooks. This keeps the hooks from firing, and can lead to hard-to-debug behaviors as a result. This is one of the biggest causes of frustrating confusion I see for people writing their own derivations. Some construct that depends on hooks is supposed to work, but doesn't, and they can't figure out why. It's cause they overrode a phase and didn't use runHook to run the pre and post phase hooks.

    • @dassurma
      @dassurma  2 місяці тому +18

      Oh cheers! Really appreciate the thorough review. I’ll add those to the video description. The remark about the hooks is interesting. That was something I definitely misunderstood and I suspect did cause a lot of headaches lol.
      Wrt containerization: I actually had that on my TODO list to check if you can have your build run in a container, and I never got around to it. Can derivations opt out of the containerization? Or how does bootstrapping work on Linux?

    • @tejing2001
      @tejing2001 2 місяці тому +15

      @@dassurma Containerization is a nix option, controlled in nix.conf or on the command line with --sandbox or --no-sandbox. It's off by default on darwin, I think because the sandboxing tech available on darwin causes too many problems, but on linux it's on by default. The sandbox only has the closures of the store paths mentioned in the .drv available in it. Nothing else. As far as I know, there's no way for a derivation to skip containerization; if your build can't work in a container, then it really isn't a proper nix build in the first place, so it isn't really viewed as sensible to give that option, especially considering the security implications of building other people's (not necessarily trusted) derivations.
      Bootstrapping stdenv in nixpkgs (in linux or darwain, afaik) is done without reference to the host system, because it instead starts with a precompiled set of tools, downloaded much like source code is. Those precompiled tools are very rarely updated, and extra care is taken to ensure provenance when they are. I believe several separate groups build them independently and check that they get bit-for-bit identical results, among other things. They don't really need to be updated until you reach a point where the latest version of the compiler can no longer be built with them, anyway.

  • @sandhilt
    @sandhilt 24 дні тому

    Please, make more videos about Nix! Amazing and astonishing content!

  • @TheMarkman1995
    @TheMarkman1995 Місяць тому

    This is really well done and useful, been trying to wrap my head around nix for a few months or a year at this point. Still very far down the rabbit hole to explore but this was crazy useful!!!

  • @Loige
    @Loige 22 дні тому

    Honestly, the best nix video I have seen so far! Thanks, Surma!

  • @WeshalbDennNicht
    @WeshalbDennNicht 2 місяці тому +1

    What a great and helpful video for anyone trying to get a first, or a second deeper grasp on what Nix is and how it works. Thank you!

  • @wildwestrom
    @wildwestrom 2 місяці тому +2

    This is superb! I think this is the best tutorial I've seen yet.

  • @nomadtrails
    @nomadtrails 2 місяці тому

    Kudos on an incredibly well made video. This is absolutely the foundational knowledge I needed that fits between "Why to use" and "How to use" which are well represented elsewhere.

  • @_____vieve
    @_____vieve 24 дні тому

    BANGER. thank you sm for this cool video. i’ll rewatch this once i try nix

  • @YaroKasear
    @YaroKasear 2 місяці тому +2

    Make more. With content of this quality you deserve more subs!

  • @kaungminkhant9790
    @kaungminkhant9790 Місяць тому

    Honestly, I love the explanation on the topic, and I would like to request more on the topic. Mind blown by how well it is presented. I myself trying out Nix and want to get started. The problem was finding where to start. Thanks a lot for the video!

  • @DenisFalqueto
    @DenisFalqueto 24 дні тому

    This is the documentation I was looking for! Thank you so much!

  • @oOBromOo
    @oOBromOo Місяць тому

    Great video, was very helpful! Interested in nix for a long time and this helps a lot to understand nix and all of its meanings better.

  • @amanueltigistu8268
    @amanueltigistu8268 Місяць тому

    this is just a great explanation of nix that i ever heard. please make more videos about nix. Thanks.

  • @sirpiplin9948
    @sirpiplin9948 2 місяці тому +1

    The video we needed, not the video we deserved! Amazing Job!

  • @xorlop
    @xorlop 2 місяці тому

    I just gave my first talk that explained similar concepts… but dang! Your explanation is amazing! This is just great!

  • @Rypervenche
    @Rypervenche 2 місяці тому +2

    Extremely well done! You probably don't use this, but if you ever do a video on NixOS, I'm here for it!

  • @theutz
    @theutz 2 місяці тому +1

    I needed this a year ago! But I’m happy that it’s here now. :)

  • @networkException
    @networkException Місяць тому

    One can start wars over whether "with;" is encouraged or not. In my opinion, sometimes it's just the most elegant way to express yourself without repetition.

  • @databasemadness
    @databasemadness 2 місяці тому

    The editing and explaining of this video is insane

  • @iChrisBirch
    @iChrisBirch 2 місяці тому

    Great video. Just enough content that I wanted to watch it all and enough teasers to make me go research some more.

  • @At-Dawn-We-Ride
    @At-Dawn-We-Ride 2 місяці тому

    Thank you for this very informative, nicely balanced video. The documentation situation for Nix is indeed not ideal, so I appreciate your work of collecting various distributed pieces of pertinent information and combining them into a "digestible" format. 👍

  • @hhhnnn9195
    @hhhnnn9195 2 місяці тому

    Thank you soo much! This was the Tutorial new users need, and I felt was kind of missing by the official documentation.

  • @matthiasbendewald1803
    @matthiasbendewald1803 Місяць тому

    Best video i saw this year, just awesome, THANK you!

  • @Mendez_84
    @Mendez_84 2 місяці тому

    I've been hearing a lot about nix recently but haven't bothered to check it out. Maybe I will take a look now. Thanks for the video

  • @JordanShurmer
    @JordanShurmer 2 місяці тому +3

    Thank you Surma. excellent video

  • @ejiek
    @ejiek 2 місяці тому

    Thanks! That is an amazing learning experience! Pleasant motioncanvas graphics, well pased explanation, relaxing music and colors. I'm happy that UA-cam got me here. Subscribed and patiently waiting for more =]

  • @yanisfourel
    @yanisfourel 2 місяці тому

    That is such an incredible video. Thatns for your hard work

  • @povilasn8239
    @povilasn8239 2 місяці тому

    Awesome video !!! Wish i had it when i just started learning, but you still managed to fill in some knowledge holes for me.

  • @oskarboer1511
    @oskarboer1511 2 місяці тому

    Thank you for making this super clear explanation!

  • @kylemoran455
    @kylemoran455 2 місяці тому +1

    This is great! Do flakes or home-manager next!!!

  • @BGroothedde
    @BGroothedde 2 місяці тому

    This is a really good video with a lot of care, thanks!

  • @hidayattaufiqur3232
    @hidayattaufiqur3232 2 місяці тому

    thank you so much for this video! such a great explanation, you're awesome!

  • @SinhNguyen-tz6us
    @SinhNguyen-tz6us 2 місяці тому

    Great video. I loved your OTMT podcast.

  • @meyou118
    @meyou118 2 місяці тому

    best description about nix - great video

  • @DipsankarMaity
    @DipsankarMaity 2 місяці тому

    Loved It. Keep the videos coming Surma.

  • @blacklistnr1
    @blacklistnr1 22 дні тому

    Cool video! exactly what I needed :))
    Can you please also do a follow-up on replacing docker?
    The way I currently see it it's more of a one-time temporary thing (e.g. nix build, nix develop). I'd be very interested to see how a production deployment would look like

  • @adexiofan1232
    @adexiofan1232 Місяць тому

    This was very well done good sir.

  • @bryanhonof
    @bryanhonof 2 місяці тому

    Cool, loved the visualizations!

  • @Majiy00
    @Majiy00 2 місяці тому

    Great video! look forward to the next one.

  • @shmuel-k
    @shmuel-k Місяць тому

    Great video, thank you!

  • @takumicrary4396
    @takumicrary4396 Місяць тому

    God what a great explanation

  • @ivanicguildmember2844
    @ivanicguildmember2844 2 місяці тому

    Elegant explanation. Much tanks for making this video. Could you also make a video explaining the machinations of NixOS too?

  • @gueyenono
    @gueyenono Місяць тому

    Do you plan on making more Nix content? Thank you very much for such a polished and informative video.

  • @miquelvazquez4544
    @miquelvazquez4544 2 місяці тому +1

    Great video! Can you elaborate on how it compares (pros and cons) with docker?

  • @carneloot
    @carneloot 2 місяці тому +1

    I would love to have more videos on this series (this is now a series, right?). Personally I’d love to know more about home manager, but I’m sure there is a lot more to talk about on the nix ecosystem

  • @leandronicolas1
    @leandronicolas1 2 місяці тому

    Someone please ask for this to be added to the wiki and awesome-nix repo. Awesome video!

  • @roycrippen9617
    @roycrippen9617 2 місяці тому

    Dude sick video!

  • @TheAndreArtus
    @TheAndreArtus Місяць тому

    Mathematically a function takes 1 input and produces 1 output. Multiple arguments can be passed (and returned) as a tuple or by currying.

  • @MrAzulay
    @MrAzulay 2 місяці тому

    Great content as always, Surma! I’m also genuinely curious to how you find it work as a replacement of docker on your servers.

  • @rok4028
    @rok4028 Місяць тому +2

    22:56 Now that we have the Nix Trinity, can we expect a full systematic theology?

  • @badr_mo
    @badr_mo 12 днів тому

    Thanks for this video. You have touched on the very essential things that is confusing me so far.
    One more thing, I think I am missing something here, when building clang-s2, you've used in the derivation of glibc the clang-s1 derivation, which depends on system libraries. Doesnt that mean that eventuall clang-s2 also depend on system libraries?

  • @jesusa7042
    @jesusa7042 Місяць тому

    THANK YOU!!

  • @janedoe5877
    @janedoe5877 2 місяці тому

    Love this

  • @SpidFightFR
    @SpidFightFR 2 місяці тому

    Hey! Awesome video !

  • @__vyre
    @__vyre 2 місяці тому

    beautiful video 🙏 keep it up bro🫶

  • @xsharawi
    @xsharawi 2 місяці тому +1

    This video is so well made, I'm glad I watched it!

  • @luckydye
    @luckydye 2 місяці тому

    great pacing 👍

  • @ramonrames
    @ramonrames 2 місяці тому

    More videos please. ❤

  • @abhishek.01
    @abhishek.01 2 місяці тому

    Thank you!

  • @someonesalt5084
    @someonesalt5084 2 місяці тому

    Top tier vid

  • @luv2code
    @luv2code 2 місяці тому +10

    I'm curious about how it replaces docker on your servers? I understand that you would run some bit of nix software that is sort of pinned to a specific version - like a docker image. But docker is more than that. Does nix also provide filesystem isolation and a networking layer?

    • @luv2code
      @luv2code 2 місяці тому +1

      Thanks for the video, BTW. I appreciate you.

    • @gungun974
      @gungun974 2 місяці тому +4

      Personally I liked both Nix and containers. The isolation of files systems and network of docker is a pure joy and the reproducibility and sandbox of building of Nix is perfect.
      That’s why I used nix to build docker Image that I can just run with Docker.
      Nix is not a Docker killer. Nix is a Dockerfile killer

    • @tejing2001
      @tejing2001 2 місяці тому +2

      Nix doesn't provide the security benefits of docker, no. But honestly, that's not the main reason people use docker most of the time. Also, nixos and similar systems can certainly set up containers with those security benefits, if you want, and the nature of the nix store tends to make it rather easy to create such containers.

    • @leoschafer5172
      @leoschafer5172 2 місяці тому

      It's possible to use a nix derivation to build a docker container (so there are no problem is someone used :latest and the docker file fails). I don't remember where the docs for this are

    • @pythonBlender7
      @pythonBlender7 2 місяці тому +1

      I'm assuming your a sysadmin who uses docker like I do. There's a thing called nix she'll or something that makes a temp env for a package. That package could be your software. When you exit, the shell and envelope are gone I think and it's basically ephemeral like a container. Also if you think about it, that docker networking layer is only there because it has to be. Even if you are good at it like I am it's still an extra thing to remember and EVERYONE gets but by it the first time they try to send something to local host right? We'll if it's just on your system then you suddenly get to use local host again. That's nice right?

  • @ArchLars
    @ArchLars 13 днів тому +1

    I am an Arch user and I am not really looking to distro hop anymore, however I am very tempted by NixOS. It has a very mature community and I think the way it works is interesting. I would have to set off some time to get used to the userland of it, but man I am tempted just to do it. Should I? Before you say this, yes I have looked into all my usage cases and NixOS can handle all of them just fine. I would just have to get used to all the various things NixOS is good at to optimize my system and you know... as Linux users of this area, that is the _fun_ of a distro, isn't it? Agh, I am very tempted! 😄

    • @ArchLars
      @ArchLars 13 днів тому

      Also I am not looking to ever dual boot any distro or any operating system, so I wouldn't want to keep my Arch install around if I decided to do this. All in or not.

    • @dassurma
      @dassurma  13 днів тому +1

      Honestly, my recommendation is to go for arch with nix rather than go full NixOS. NixOS is attractive from a purist perspective, but I have found it impractical for a workstation (I do like it conceptually for servers tho, but haven't taken that leap yet)

    • @seanhdka
      @seanhdka 4 дні тому

      @@dassurmawhat makes it impractical for you? wanted to switch back to a different distro since i can't use nix at work, but to be honest i can't ever go back to something else. just being able to for example have a stable zfs release but have the newest kde release is just to good. also love the fact that my system is inherently documented, though i haven't used home manager yet

  • @joshaushessen2270
    @joshaushessen2270 Місяць тому

    It's a great video and an angle, I haven't seen before. Thanks for that.
    The only thing I didn't understand is the following: If clang has a dependency onto libc, then the hash of clang is dependent on the hash of libc. And if libc is build with clang then its hash is dependent onto clangs hash. Isn't that bad? Or why is it not?

  • @acriliqueofc
    @acriliqueofc 2 місяці тому

    Great video!

  • @erwin757
    @erwin757 Місяць тому

    You talked about replacing docker. How did you do that and how do you manage your containers? I did not fully understand that jump to connecting nix with docker replacement

  • @NostraDavid2
    @NostraDavid2 Місяць тому

    Yooo, that Dutch pronunciation of the research paper's title was _tight_! That was so clean! I see you live in the UK, but did you live over here for a bit or what?

  • @yoyonel1808
    @yoyonel1808 2 місяці тому +3

    at 5:49 the error message in not related to the code:
    /* f = */
    {a, b, c}: a + b + c
    f {a = 1; b = 2;}
    # error: function called
    # without requirement argument 'b'
    It's not 'b' but 'c' (i hope :p)

  • @RonaldoHabibiDev
    @RonaldoHabibiDev 2 місяці тому

    great ! Thanks !

  • @peacefulexistence_
    @peacefulexistence_ Місяць тому

    1:15 software is usually distributed as binaries since a binary has a smaller file size, less dependencies, and you can directly run it rather than compiling it (which in the case of something like Chromium would take several weeks of 100% CPU usage if you were to do it on an old office PC from 2010s, if it would even finish and not run out of RAM, which it probably would)
    1:20 Firefox is Open Source, under the Mozilla Public License which is a weak copyleft license.
    2:15 no, it doesn't, the source code gets compiled on a compiler farm of each Linux distro, uploaded to its repositories, and the user downloads the resulting binaries. Unless you run Gentoo.

  • @Shujaathullakhan
    @Shujaathullakhan Місяць тому

    its a great video. Had a doubt on how you create these videos? what is the software used?

  • @rakeshvenkat9971
    @rakeshvenkat9971 2 місяці тому

    Brilliant!!!!

  • @korigamik
    @korigamik Місяць тому

    Great video, how do you create the animations and the voice overs? Will you share the source code for this video?

  • @EmmanuelMess
    @EmmanuelMess 2 місяці тому +1

    If this is actually able to compile the Qt frontend, it would be incredible, as Qt is very difficult to compile replicably, even with Docker.

  • @R24-q6b
    @R24-q6b 2 місяці тому

    I really liked the video but can you tell me what did you used to create such a good quality video.

    • @dassurma
      @dassurma  2 місяці тому

      That’s the wonderful Motion Canvas :)

  • @extenos
    @extenos 19 днів тому

    better title: explaining nixos in forza motorsport terms

  • @ZackMitkin
    @ZackMitkin 2 місяці тому

    Very good video, the music is very disturbing though. Any change you can re-upload without such loud music?

  • @BboyKeny
    @BboyKeny 2 місяці тому +3

    That's a bold claim indeed. Can it install Crisis on my Tamagochi?

  • @Kotz_en
    @Kotz_en 2 місяці тому

    I love how you animated the code throughout the video. Is there a tool that performs these transitions automatically, or did you create them manually when editing the video?

    • @cinderwolf32
      @cinderwolf32 2 місяці тому

      Motion Canvas

    • @Kotz_en
      @Kotz_en 2 місяці тому

      @@cinderwolf32 Thanks!

    • @cinderwolf32
      @cinderwolf32 2 місяці тому

      I think we were sorely lacking effective presentation and communication techniques for highly technical information and concepts, and I'm continually impressed by how everyone utilises Motion Canvas.

  • @AnthonyBullard
    @AnthonyBullard 2 місяці тому

    It’s simple: I see Surma, I subscribe.

  • @andreujuanc
    @andreujuanc 2 місяці тому

    Amazing, quick question regarding "placed docker on my servers". Do you do cgroups by hand? how do you handle sandboxing?

  • @AvisekDas
    @AvisekDas 2 місяці тому

    I love you Surma

  • @TheDistroHopper
    @TheDistroHopper Місяць тому

    I am watching this video just for motion canvas

  • @danser_theplayer01
    @danser_theplayer01 2 місяці тому

    Let me guess, nix making new users is the equivalent of me compiling and testing a program on a VM for OS that I don't have.

  • @mathiswellmann6858
    @mathiswellmann6858 2 місяці тому +2

    Nix is truly the best thing that happened to the linux ecosystem. Been using it for 1.5 years now and loving it. But it has a pretty steep learning curve I must admit, harder than Rust or CUDA IMO.

  • @amigalemming
    @amigalemming 26 днів тому

    Last time I installed Nix on Mac there was no need for an extra partition for Nix.

  • @SirSomnolent
    @SirSomnolent 2 місяці тому +3

    Is it mandatory that I dye my hair blue before installing nixos?

    • @emmaflies199
      @emmaflies199 Місяць тому

      No, you can also go the programmer socks and skater skirt route.

  • @khanra17
    @khanra17 2 місяці тому +1

    9/10
    -1 for placing the nix language syntax in the beginning part.
    Felt overwhelming and weird!