I built my own memory profiler (in Rust, on Linux)

  Рет қаралды 58,842

fasterthanlime

fasterthanlime

Күн бұрын

To try everything Brilliant has to offer-free-for a full 30 days, visit brilliant.org/fasterthanlime
The first 200 of you will get 20% off Brilliant’s annual premium subscription.
This video was sponsored by Brilliant.
Follow me on Mastodon: hachyderm.io/@fasterthanlime
Support me on Patreon or GitHub: fasterthanli.me/donate
Source code for the memory visualizer: github.com/fasterthanlime/mevi
"The Linux Memory Manager" book (Lorenzo Stoakes): linuxmemory.org/
(Reference continue below)
Contents
00:00 Intro
01:09 Memory fragmentation explained with cars
02:26 Virtual memory 101
06:10 Observing simple programs with mevi
10:30 Sponsored segment (real)
11:33 Why does this Rust program leak memory, visualized
13:30 mevi is Rust on the front & back
15:40 userfaultfd: the reason why mevi works (slowly)
18:13 The hard bits
21:06 Some bigger programs seen through mevi
22:15 Y'all are so good to me
More references
The Quest for Netflix on Asahi Linux (David Buchanan): www.da.vidbuchanan.co.uk/blog...
Making our own executable packer: fasterthanli.me/series/making...
Swiss Tables Design Notes (Abseil): abseil.io/about/design/swisst...
SwissTable CppCon talk (Matt Kulukundis): • CppCon 2017: Matt Kulu...
Live migration: en.wikipedia.org/wiki/Live_mi...
Chromium’s Zygote process: chromium.googlesource.com/chr...
bytehound memory profiler: github.com/koute/bytehound

Пікірлер: 115
@fasterthanlime
@fasterthanlime Жыл бұрын
To try everything Brilliant has to offer-free-for a full 30 days, visit brilliant.org/fasterthanlime The first 200 of you will get 20% off Brilliant’s annual premium subscription.
@mzg147
@mzg147 Жыл бұрын
Yes!! Go get that sponsors boyy
@PaulFisher
@PaulFisher Жыл бұрын
Stack that paper baby
@aleksandermirowsky7988
@aleksandermirowsky7988 Жыл бұрын
Honestly, every one of your videos always feel like a blessing. It's reminiscent of a sage descending from the mountains to share his sacred knowledge with the village folk.
@fasterthanlime
@fasterthanlime Жыл бұрын
I see myself more like a fool tumbling down the hill every so often to bestow the curse of knowledge upon others, but I think the idea is roughly the same!
@charetjc
@charetjc Жыл бұрын
@@fasterthanlime You have an amazing ability to digest all you learned into a concise, interesting, and easy-to-follow manner. This video is excellent.
@JheregJAB
@JheregJAB Жыл бұрын
every one of your videos up until now has been right on the perfect edge of "I understand, but we're stretching it". I've got to be honest, this one managed to get over my head. That's not bad, its a challenge. Gonna have to rewatch it a couple times and do some extra research on top of it, I think.
@fasterthanlime
@fasterthanlime Жыл бұрын
Thanks for the feedback! That video definitely warrants at least a couple follow-ups, I have unscripted ideas that I think could be neat. Gotta change it up a little, those videos are an enormous amount of work.
@abiiranathan
@abiiranathan Жыл бұрын
PHD-esque stuff. Mind-blowing 🤯
@multispectrum
@multispectrum Жыл бұрын
This was absolutely fantastic. A follow up video or resources to explain things in more detail for people who don't have much low level experience would also be great.
@fasterthanlime
@fasterthanlime Жыл бұрын
I have a couple in mind, but can you give me a few areas in particular you'd like cleared up?
@multispectrum
@multispectrum Жыл бұрын
​@@fasterthanlime Again, fantastic work, you're a really great teacher. Watching it again, I wrote down things that I have questions on. There are definitely resources on most of things available and I have a good place to start learning from now. The largest gap in available resources to me seems like eBPF. What defines the memory sections (ro, rw, re)? (Making our own executable packer is on my list to read yet.) TLB makes sense for virtual->physical, but what does walking the page table mean? (Also how does the TLB cache recent memory accesses? Is there a large performance hit to TLB misses? And can the TLB only work for a single process at a time? How does flushing work?) What exactly is a page fault? What is stack/heap, and how to they relate to syscalls (break, mmap, madvise, etc)? Does madvise just allow the kernel to remove pages from the resident memory, but they're still in the virtual memory? What is malloc, malloc_trim, calloc, realloc, free, and how do they relate to syscalls, heap, virtual address space, etc? With your mention of eBPF I lost all understanding of what eBPF is. I thought that it was only for packet manipulation and statistics collection on network traffic. A video on eBPF would be awesome. Everything after ~18:00 I was completely lost. That could probably take a decade of learning. (ptrace, userfaultfd, what is a fd?, what's a setuid binary, self-tracing processes, PID namespaces, seccompbpf?)
@dnullify100
@dnullify100 Жыл бұрын
Your content is the absolute nexus of production quality, content quality, and approachability. The thoughtful and smooth crescendo of complexity that keeps one engaged for the whole video/story.
@FryuniGamer
@FryuniGamer Жыл бұрын
"My previous video about this was, in fact, correct. I was as shocked as you are" I wish I had that confidence, but even more I wish I was at the level of saying such a thing.
@walksanator
@walksanator Ай бұрын
Thats not co fidence though...
@sambazeley5366
@sambazeley5366 22 күн бұрын
I watched this video all the way through assuming that this was another big programming channel. I was surprised to see how small your channel is. There is so much quality!
@meegleeto
@meegleeto Жыл бұрын
I can't believe the "this video is sponsored by" bit actually paid off
@fasterthanlime
@fasterthanlime Жыл бұрын
It was all just practice 🧐
@driedurchin
@driedurchin Жыл бұрын
This video exposes a lot of "false dogma" IMO. You traditionally hear the simple explanation of the cost of dynamic vectors, usually saying something like "if a push exhausts the capacity, you have to reallocate and copy everything over", which is *morally* true, and maybe was *actually* true 20 years ago. Nowadays, on modern OSes its interesting to see how it's not the case. Yet another reason to never preemptively optimize. Measure first!
@louisfifteen
@louisfifteen Жыл бұрын
"This town aint big enough for both of us" by "The Sparks" The one playing the piano is what this guy reminds me off. They were brilliant and so is he.
@SamSargent-kh7gl
@SamSargent-kh7gl Жыл бұрын
It's such a relief that people like you make content for us like this. This is exceptional, cheers.
@ahuggingsam
@ahuggingsam Жыл бұрын
as always I'm gonna have to go over some of this stuff multiple times, but I'm learning so much. Thanks for making these videos Amos, I doubt I could clearn about this stuff without someone like you making it engaging.
@artifishul
@artifishul Жыл бұрын
Love this content. Thanks for all the work you put in to explain this so well
@kehaarable
@kehaarable Жыл бұрын
Your videos are great. I was looking for some rust videos when I stumbled upon them. I've been programming for about 20 years so most videos are painfully slow. Your videos always touch on subjects that I've never had to deal with. I've not learnt a huge amount of rust, but my understanding of how systems actually work has grown a lot, and enticed me to think more about the tools I take for granted every day and to think about in earnest how I would build them. So thank you!
@nindalf
@nindalf Жыл бұрын
Fantastic video, thank you for making it. I'd love to see a video of using mevi to optimise existing programs.
@lejee_
@lejee_ Жыл бұрын
great video, as always :) btw. nice seeing you have a (real) sponsor now!
@kickeddroid
@kickeddroid Жыл бұрын
What's crazy is I looked this up earlier this morning, taking a break now and watching youtube I see this lmao
@Dygear
@Dygear Жыл бұрын
Crushed it again Amos! So many things to try this out on!
@nikandfor
@nikandfor Жыл бұрын
Super cool! I love the observability, and this is the next level!
@desuburinga
@desuburinga Жыл бұрын
Amazing video, like everyone else mentioned, absolutely mind blowing stuff! Keep up the great work and congrats on the sponsorship!
@appelnonsurtaxe
@appelnonsurtaxe Жыл бұрын
That was both interesting and very enjoyable to watch! Thanks a lot for making these videos.
@zperk13
@zperk13 Жыл бұрын
Congrats on getting sponsored!
@employee9911
@employee9911 Жыл бұрын
Really enjoy content like this
@simonfarre4907
@simonfarre4907 Жыл бұрын
You haven't looked at RR code base before? A lot of this stuff's in there, although, your project I think is a better source to learn this stuff from since it's probably smaller in scope (and it's in Rust, RR is written in C++). But you've got the sending of fd's over a socket, the injection of syscalls, etc and all that really cool Linux stuff.
@fasterthanlime
@fasterthanlime Жыл бұрын
I've never cracked rr open (but I've used it a couple times!) but I 100% trust you on that. mevi definitely makes for a smaller surface to study, and you can always drop into some of the crates it uses if you're interested in a specific abstraction!
@jorgeosorio1613
@jorgeosorio1613 9 ай бұрын
this video was great, I loved the introduction.
@OhadLutzky
@OhadLutzky Жыл бұрын
Excellent job, and congrats on the sponsor!
@Onkoe
@Onkoe Жыл бұрын
I love these videos! I’d happily watch a one or two hour version. I have ADHD, so your articles are a lot harder for me, but these videos are perfect!!!
@flippert0
@flippert0 5 ай бұрын
While way over my head for now, this feels amazing! One day, I might be able to understand what's going under the hood.
@patryk6769
@patryk6769 Жыл бұрын
Thank you Brilliant for sponsoring this video ❤
@craigcraig6248
@craigcraig6248 Жыл бұрын
Wow, great video. Im glad i found this channel.
@MrMariy0
@MrMariy0 Жыл бұрын
very interesting, as always!
@fluffy_tail4365
@fluffy_tail4365 Жыл бұрын
Incredible video as usual
@bakabaaka2681
@bakabaaka2681 Жыл бұрын
Damn... Great video man.
@asadullahfarooqi254
@asadullahfarooqi254 Жыл бұрын
yo brah it was amazing, can't wait to see the eBPF :)
@zperk13
@zperk13 Жыл бұрын
Thanks for captions!
@fasterthanlime
@fasterthanlime Жыл бұрын
Thanks! I used Whisper for these but even then it's a solid 2.5x-the-runtime of manual cleanup/sync work :)
@jackevansevo
@jackevansevo Жыл бұрын
Blown away by every single one of these videos
@gruelingpine1857
@gruelingpine1857 7 ай бұрын
this is pretty cool! Your profile pic reminds me of the scrap metal artist from the Iron Giant
@flyingsquirrel3271
@flyingsquirrel3271 Жыл бұрын
I'm so happy that you casually use the term "kibibytes" :D (I had this discussion a few times with unteachable people...)
@clo4
@clo4 Жыл бұрын
Yooo get that bag! Good job Amos!!
@__mrmino__
@__mrmino__ Жыл бұрын
Technically sections in an ELF don't need padding. The section header contains the size field, the loader in the kernel can just load the non-zero stuff and leave the rest. Filling ELF section with zeroes ensures that the page is also filled with zeroes, instead of garbage. It has nothing to do with page alignment. The virtual *adresses* still need to be page aligned though, as most MMUs don't support setting memory attributes on anything other than a whole page.
@TobiasFrei
@TobiasFrei Жыл бұрын
Oh, these great contributions of yours. You *do* have an impact on the way I think about- and write Rust. Looking forward to some eBPF. Will you go the Aya way? 🤓🐝
@TobiasFrei
@TobiasFrei Жыл бұрын
Or no. It won't be the Aya way. Just as likely you're gonna roll it yourself 😋
@fasterthanlime
@fasterthanlime Жыл бұрын
I've naturally looked at Aya since I've used it before for networking, but I'm unsure whether it'll do the job for that project. Time will tell!
@chylex
@chylex Жыл бұрын
I love the visualization of memory allocations
@bowarc
@bowarc Жыл бұрын
Rly cool, keep up the content, it's really interesting l!
@musikosv
@musikosv Жыл бұрын
Very interesting, thanks for sharing!"
@gpugpugpu
@gpugpugpu 7 ай бұрын
Another fire fasterthanlime video let’s GOOOOOOOOO
@Leik000
@Leik000 Жыл бұрын
Going from "sponsored by coffee" to "sponsored by Brilliant". KZbin achievement unlocked.
@fasterthanlime
@fasterthanlime Жыл бұрын
All that caffeine finally paid off!
@johanngambolputty5351
@johanngambolputty5351 Жыл бұрын
Not sure I understood any of that, but I was impressed ;)
@Vampirat3
@Vampirat3 Жыл бұрын
@fasterthanlime , you get mad respect. great video thank you.
@Otakutaru
@Otakutaru Жыл бұрын
I didn't expect the linux kernel to be so fiddly. Is everything related to low level OS that challenging? For example, memory management on windows? Because I got scared
@fasterthanlime
@fasterthanlime Жыл бұрын
I think the short answer is yes. But the good news is that it's "knowable", and then you slowly change from feeling intimidated by it to feeling irritated by it at times 🙃
@oyewodayo
@oyewodayo Жыл бұрын
You're a good teacher. You explain things differently, even a 2 years old kid will understand anything you explain.
@EricTorreborre
@EricTorreborre Жыл бұрын
Your videos are always mind-blowing, not only for their content but also for the quality of the presentation. Kudos!
@heyiamigor
@heyiamigor Жыл бұрын
Could you please share your code editor setup? I saw you using VSCode and vim extension, what other configs/extensions do you use? Thx!
@CramBL
@CramBL Жыл бұрын
Great video. What's the website you use for making those sketches at @3:11 for example?
@fasterthanlime
@fasterthanlime Жыл бұрын
That's draw.io / diagrams.net!
@brazni
@brazni Жыл бұрын
17:29 Don't tell me what to do magic mind reading slides!
@JustAnotherLight
@JustAnotherLight Жыл бұрын
At the beginning of the video, I thought Brilliant's starting a Rust course!
@pkoch
@pkoch Жыл бұрын
If only my OS class was this good. ❤
@MateuszWykurzIsAwesome
@MateuszWykurzIsAwesome Жыл бұрын
Thanks!
@fasterthanlime
@fasterthanlime Жыл бұрын
Thank you for your support !
@ExCyberino
@ExCyberino Жыл бұрын
rm -rf = rename --recursive --flawlessly Basically solves the slash problem in all files
@user-ed5qx1ih3i
@user-ed5qx1ih3i Жыл бұрын
Your doctor is great!
@bxnny0374
@bxnny0374 Жыл бұрын
Have nothing to say, just commenting to help this video out so more people can see it :) insanely high quality
@DarrienGlasser
@DarrienGlasser Жыл бұрын
Buses and trains don’t exist in that universe I didn’t know you visited America recently :o
@oyewodayo
@oyewodayo Жыл бұрын
Please do a series on Axum indepth.
@kowalkem
@kowalkem Жыл бұрын
Missed opportunity here - should have been built on Gentoo or at least Arch 😉 In all seriousness - massive thumbs up 👍
@fasterthanlime
@fasterthanlime Жыл бұрын
Oh I've served my time in both the Gentoo & ArchLinux jails, I'm free now, I can use Ubuntu and still have street cred 😎
@YTCrazytieguy
@YTCrazytieguy Жыл бұрын
Yay sponsorship!
@kasvith
@kasvith Жыл бұрын
Can you do Zig vids as well
@Verrisin
@Verrisin Жыл бұрын
so, do we see if Firefox is leaking memory in the "third way" ? That would be a cool thing to find out after the effort.
@fulgorete
@fulgorete Жыл бұрын
This is not a trivial subject. Good work overall
@Verrisin
@Verrisin Жыл бұрын
damn, ok, growing a Vec looks a LOT nicer than something like ArrayList in JVM, which I think DOES copy the array. - I might be wrong and it does some magic behind the scenes, but this looks beautiful ...
@m4rt_
@m4rt_ Жыл бұрын
could you make a thing like RemedyBG... but for linux?
@focusEngineered
@focusEngineered Жыл бұрын
AMAZING
@sammay1540
@sammay1540 Жыл бұрын
Gold
@as-qh1qq
@as-qh1qq Жыл бұрын
This is way above my pay grade.
@thepetesmith
@thepetesmith Жыл бұрын
I’d like to see faster than lime’s car.
@mint_fresch4329
@mint_fresch4329 6 ай бұрын
imagin u#r talking about linux kernel very basic/complex stuff and get an normal sponsor xD, bro u made it xD
@versacebroccoli7238
@versacebroccoli7238 Жыл бұрын
It's so crazy that the minimum memory a program can allocate (4k) used to be sold as high end ram sticks. I was reading a comment on some other tech video and a person said their computer could have up to 20 4k ram cards. But that would take all their expansion slots.
@fasterthanlime
@fasterthanlime Жыл бұрын
It was another time, for sure! From devblogs.microsoft.com/oldnewthing/20200728-00/?p=104012 Huge pointers could refer to memory blocks larger than 64KB by adjusting the segment whenever the offset overflowed.¹ Pointer arithmetic with huge pointers was computationally expensive, so you didn’t use them much.²
@gakman
@gakman Жыл бұрын
lol "Stop reading these slides and pay attention"
@Dragon-xd4ru
@Dragon-xd4ru Жыл бұрын
Keep making more videos pls 🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏
@jeffg4686
@jeffg4686 Жыл бұрын
nice
@Verrisin
@Verrisin Жыл бұрын
I wonder if this needed so much unsafe code, it would have been easier to write in Zig ? Probably not, but I wonder. (and yes, it would probably not share code with browser) - Also, I have zero clue how one would even research all the documentation to make all this crazy stuff work ... - How to even figure out all the magic kernel stuff? And how to do it from something other than C ? EDIT: 22:22 - I see. So that's how! Naruhodo.
@fasterthanlime
@fasterthanlime Жыл бұрын
I've seen that same "we switched from unsafe Rust to Zig" article that you have, but in that case, no, Rust was plenty comfortable, thanks to a wealth of crates that exposed all the system interfaces I wanted :)
@Verrisin
@Verrisin Жыл бұрын
@@fasterthanlime hehe, yup. - Awesome to know! - It's good to know it can be abstracted away into a safe crate.
@justaguy1299
@justaguy1299 Жыл бұрын
This made me think about a video about the same topic I saw a while ago, there they made a tool that compacts the fragmented memory pages of a process. Might be an interesting watch kzbin.info/www/bejne/mWK4c32Ym7dgfpI
@fasterthanlime
@fasterthanlime Жыл бұрын
Yes! I've been meaning to talk about MESH - anything Emery Berger is involved in is sure to be fascinating :)
@sudiproy4413
@sudiproy4413 8 ай бұрын
😨 18:13
@xmeo209
@xmeo209 4 ай бұрын
I have no idea what this man says, but its very uhm.. interesting?
@rotteegher39
@rotteegher39 Жыл бұрын
Everytime you say "Mevy" I hear "Bevy" instead (rust game engine)
@muneebdev
@muneebdev Жыл бұрын
"a lesser man"
@kaioh33
@kaioh33 Жыл бұрын
Pagliaci joke😂😂😂
@motbus3
@motbus3 Ай бұрын
For a month? Hummm...
@victorfds
@victorfds Жыл бұрын
I don't understand 7 in each 10 words you say.
@fasterthanlime
@fasterthanlime Жыл бұрын
Is my pronunciation that bad?
@victorfds
@victorfds Жыл бұрын
@@fasterthanlime absolutely not. I have a little bit knowledge about low level programming. The topics looks so deep that I can't get it.
@fasterthanlime
@fasterthanlime Жыл бұрын
I have quite a few videos about that but I've been slowly figuring out how to do more accessible videos with a tighter scope. I'll get it right someday!
C++ vs Rust: which is faster?
21:15
fasterthanlime
Рет қаралды 371 М.
Self-referential structs (in Rust)
27:21
fasterthanlime
Рет қаралды 51 М.
it takes two to tango 💃🏻🕺🏻
00:18
Zach King
Рет қаралды 29 МЛН
어른의 힘으로만 할 수 있는 버블티 마시는법
00:15
진영민yeongmin
Рет қаралды 8 МЛН
Can You Draw The PERFECT Circle?
00:57
Stokes Twins
Рет қаралды 97 МЛН
Why does this Rust program leak memory?
35:24
fasterthanlime
Рет қаралды 56 М.
GitHub Actions Feels Bad
26:27
fasterthanlime
Рет қаралды 90 М.
What are immutable distros, and are they the future of Linux?
15:23
The Linux Experiment
Рет қаралды 97 М.
POV: I'm on my third coffee and you just asked me how the internet works
21:20
Constructors Are Broken
18:16
Logan Smith
Рет қаралды 99 М.
But, what is Virtual Memory?
20:11
Tech With Nikola
Рет қаралды 186 М.
Why Compile a Linux Kernel from Source?
13:38
DJ Ware
Рет қаралды 27 М.
wyłącznik
0:50
Panele Fotowoltaiczne
Рет қаралды 23 МЛН
Дени против умной колонки😁
0:40
Deni & Mani
Рет қаралды 9 МЛН
How charged your battery?
0:14
V.A. show / Магика
Рет қаралды 2,6 МЛН