I Cry Every Time Jonathan Blow Says I Don't Have Deep Knowledge
Posted by EasyLowHangingFruit@reddit | ExperiencedDevs | View on Reddit | 105 comments
Hi folks, hope y'all doing good!
What hard skills and/or deep knowledge do you think every Senior SWE should positively have in the context of building and maintaining scalable, highly available, mission critical distributed systems?
What immediately comes to mind for me is:
- How scalable dist systems work (caching, vert and hor scaling, sharding, microservices, etc)
- Logs querying and analysis
- Distributed tracing debugging
- JVM metrics (i.e. threads, etc) and memory profiling
- Memory management and profiling at the local level
- Some SQL query tuning
- GitFlow (or any other strat), hotfixing and cherry picking
- Knowledge of how app layer protocols work (HTTP, FTP, SMTP, and DNS)
- Maybe some stress testing?
What would you add to the list?
Successful_Ad5901@reddit
A decent programmer with very strong opinions. Favors doing things his way instead of how most other devs would approach a problem.
Braid was a masterpiece from a gaming perspective. This does not make him a a extremely good programmer though. The witness was also good. But neither of these two games require raw programming talent.
Making your own language because you don’t really agree with how the options look is.. well, it’s a for effort. But jai isn’t exactly ground breaking stuff in any way. It just conforms with how he wants to program and feels like it is affected very little by external input.
The current game he is working on does not seem like a particularly good game. I’m honestly not sure what he is trying to prove. Finish it and ship it already
demosthenesss@reddit
A bunch of these are really specific to a given type of senior SWE.
You can be a senior SWE without knowing a lot of these, depending on the stack/domain you work in....
yetiflask@reddit
99% of the posts in this sub are people creating event-based CRUD microservices. Once you accept that, all posts here make sense.
Icy-Pay7479@reddit
I see you've got 8 years of React in FAANG, so let's dig into JVM garbage collection.
the-code-father@reddit
Where in FAANG are you using React?
ThicDadVaping4Christ@reddit
Dawg really? It was created at Facebook
the-code-father@reddit
Yea and internally almost everything is using Hack? Similarly at Google it's actually challenging to find a position where you are writing Angular. Most things are on one of the other older frameworks
CANT_TRUST_DONALD@reddit
clearly you haven't actually worked at Meta
the-code-father@reddit
No, I'm about to start. My hiring manager told me I was going to have to use hack. I'm glad that React is widely used
astatine757@reddit
Hack mostly replaces/augments backend PHP due to type safety concerns, but all front-end stuff is gonna be either react, kotlin or swift
the-code-father@reddit
Gotcha, I think my HM was exclusively backend before becoming a manager and I'm the first dev they are hiring for frontend related stuff. So when I asked about React they told me it wasn't really being used and I would be writing Hack
astatine757@reddit
Technically, it's all typescript for new stuff, but basically the same
Morphyish@reddit
IIRC they are using Flow as well for types
daishi55@reddit
Hack is a back end language it has nothing to do with react
EasyLowHangingFruit@reddit (OP)
I'm curious, how is React used in FAANG in terms of architecture, component styling, etc, vs smaller companies?
the-code-father@reddit
I can't compare React to React at FAANG for you but I can compare React at a small company to how Google's UI framework for Search is structured.
The biggest difference by far is in terms of structure and process. It's hard to emphasize how much overhead the scale at Google imposes on frontend changes. At a smaller company you likely rely on a mixture of 3rd party components and some shared components maintained communally or perhaps by a small team of dedicated individuals. At Search there are 100+ people working on the shared components used by the other teams. Deviating from these shared components is frowned upon, and it will take months from start to finish to get approval for a design that deviates at all from the existing UI. My team once attempted to make some minor color changes to something, and we ended up going back and forth with design leads for 5 months before just giving up on it entirely and moving forward without the UI changes.
The general structuring of code between the two was relatively similar. Preference towards smaller components and unit tests everywhere possible
33ff00@reddit
Which is pretty crazy considering how over the last three years they have completely fucked up the search itself, which to me feels more important than changing the color of a fucking button.
fojam@reddit
Isn't hack a backend language tho?
the-code-father@reddit
I'm coming from Google Search which is almost entirely rendered using Java that passes props to a custom HTML template language. JS is only used sparingly for interactivity. So it didn't sound that strange to me that Hack would be doing a lot of the rendering
fojam@reddit
Yea I mean rendering makes sense, but from my understanding, there isn't a js/frontend part of hack
BeamMeUpBiscotti@reddit
Hack has XHP which sort of lets you write HTML on the server, but anything user-facing and all modern internal tools use React.
fojam@reddit
Yea, I guess my point was that them using hack doesn't exclude them from using react, because hack is a backend framework, so they'd still probably be using some sort of framework on the frontend. ie: react
BeamMeUpBiscotti@reddit
Hack is mostly used for the web tier, backend services are written in a variety of languages and front-end web UI uses React with Flow instead of TypeScript.
jon_hendry@reddit
That’s because someone else got a promotion for producing Angular. Now someone else needs a promotion and needs to poop out something of their own.
demosthenesss@reddit
I work at faang using react actually ha
the-code-father@reddit
Idk why I'm being downvoted so aggressively for genuinely asking which FAANGs are using React, because I know it isn't Google. - A former React Dev who was bummed upon joining Google and being forced to go back to a UI framework from 2008
DreamAeon@reddit
Its the tone of your original post. Absolute denial and dismission of facts. You are definitely not asking a question.
kokanee-fish@reddit
I guarantee you there is someone somewhere at Google using React in production. And it's probably ubiquitous at all the other FAANGs.
demosthenesss@reddit
Because your post comes across as mocking the post you responded to and dismissive of the idea that FAANG engineers use React
the-code-father@reddit
Well that wasn't my intention. I'm looking forward to the chance to use React again while at Meta
Sir_lordtwiggles@reddit
Same lol
__scan__@reddit
All FAANG except perhaps Goog presumably use React, at least in internal tools if not on their public websites.
SpiritedEclair@reddit
Doesn’t AWS app thingy use React?
DependentlyHyped@reddit
Yup! I’m a senior SWE, and I’ve worked almost exclusively on compilers, fuzzers, and formal verification tooling. Know about zilch of the OP.
DependentlyHyped@reddit
Yup! I’m a senior SWE and know almost none of the things in the OP - I’ve worked pretty much exclusively on compilers, fuzzers, and formal verification tooling.
kokanee-fish@reddit
That was my first reaction, too. I'm a staff SWE with 15 YOE and my job doesn't involve "building and maintaining scalable, highly available, mission critical distributed systems" at all. I build and maintain data pipelines, applications, and machine-to-machine integrations for exclusively internal-facing use cases at a manufacturing company. The scale has a defined upper limit, the systems will never need to be distributed, and there are no SLAs around availability at all.
pwndawg27@reddit
Must be nice. I wish I could explain to some of the try-hard staff engineers I've run into that their card processing system that only services north America will never need half the shit Facebook does because well never need to scale out that far.
elektracodes@reddit
But… but… how are they supposed to market themselves as the next tech 10x developer if they don’t use all the “right” tools? What about their CVs? What about the sacred art of planning for a scale that’ll never happen just so you can extend deadlines and justify another rewrite?
Honestly, I’m disappointed to see you care about outcomes. That’s not how you build a career, sir!
pwndawg27@reddit
Lie
More like justify their positions
The "right" tools are not things you yank out of a conference that Netflix headlines or an article you read on hackernews. They're things that are easy to understand, ergonomic, and solve your current problem.
elektracodes@reddit
Exactly. There are way too many people out here building for optics, not outcomes. I’ve been burned for being too direct about that, for pushing for things that actually solve problems instead of just looking good for conference materials. Meanwhile, the folks who play the game get rewarded, even if what they ship is a mess under the hood.
Glad to see I’m not the only one who sees it.
pwndawg27@reddit
Lol why do you think devs change jobs every 4 years? Come in, implement a bunch of flashy shit, hype up the resume making yourself look like the next zucc, leave and get a 30% bump before you have to deal with the fallout.
C-suite execs are the same way, it's just a longer game.
Vivid_News_8178@reddit
Sssh, you aren’t supposed to say those things
EasyLowHangingFruit@reddit (OP)
Yeah, definitely! This is (IMO) a Backend profile that's still responsible for monitoring their deploys through Prod and dragon killing incidents in Prod.
root45@reddit
It's still scoped, even for backend. Maybe low level Java backend engineer at a company with more than 200 engineers.
tomqmasters@reddit
Half gibberish to me, I though I must just not know enough to be taken seriously.
BomberRURP@reddit
Honestly the title and field are way too wide. Senior in what? What industry? What sub field? Etc.
I mean there are foundational skills I think every dev should be familiar with, but these don’t make one a senior. They only lay a foundation off of which one can specialize and all that shit. Know basic data structures, understand code performance and complexity (five nested loops aren’t great, etc), understand paradigms (OOP, functional, imperative, etc), and some philosophical stuff like (favor simplicity over complexity, don’t prematurely optimize, etc).
But for example a senior writing embedded software will be familiar with very different things than a senior frontend senior
SocietyKey7373@reddit
I don’t view it as specific technologies as much as I do topics. All SWEs should know caching. It applies at all layers of the software and hardware stack. They should know how to debug and profile. Networking as well. There is no reason a kernel dev needs to know JVM or SQL query tuning.
lphartley@reddit
Imo none of these are mandatory. The only thing mandatory is critical thinking skills, problem solving skills and knowing how to structure code (thus structuring logic in general). The rest will follow.
CompetitiveSubset@reddit
This. Not all of those things are critical for most domain.
zayelion@reddit
I agree. I think this is the strongest take on this.
Temporary_Emu_5918@reddit
threading, multiprocessing dependency management and injection
incredulitor@reddit
The questions you're asking and the way you're framing it are going to keep you on a treadmill that takes your focus away from what you actually want to be doing, and away from building your own confidence in yourself. What makes you want to approach it in this way, placing other people as the experts and asking them to put something in front of you to keep you on someone else's treadmill, as opposed to being more focused or self-directed?
drjeats@reddit
Don't pay attention to JB when he's ranting, you'll be happier.
PrimaxAUS@reddit
I've got 25yoe at this point, and I'm starting to really think deep knowledge is far less valuable than the ability to research quickly and effectively, and grok something fast.
This space moves too quickly for deep knowledge. I used to have deep knowledge of AWS, but it's such a broad fast moving ecosystem it's hard to keep ahead of.
EasyLowHangingFruit@reddit (OP)
Absolutely! I've realized that having a clear overall picture of the desired outcome, especially one that adheres to quality standards, is generally more valuable than knowing every minute detail. This high-level vision allows you to identify not only what you understand but, more importantly, what you don't. You can then focus your investigation on those knowledge gaps and document your findings for future reference.
For instance, understanding the 12-Factor App framework (despite its critics) provides a clear model for building a web service. It defines the 'Definition of Done,' giving you a target to aim for. With this end goal in mind, you can then distinguish between your existing knowledge and the areas requiring further exploration.
Radiopw31@reddit
Holy shit, you are going to die early! Focus on one of those… in fact get good with soft skills above all else.
atomheartother@reddit
I don't think Jonathan Blow knows how to do most of these, he probably just means low-level programming and systems/shell knowledge. Without context on that quote that is.
nsxwolf@reddit
He talks like he’s the smartest software engineer in the world, and maybe he is, but he’s never going to have to prove it because he spends 100% of his time in indie game dev.
He likes to throw out random shade that most software engineers are weak and overpaid, which makes a lot of people defensive.
We’re all out here still, somehow making a living without his permission.
HarpuiaVT@reddit
I see Blow as an artist more than a SWE, also I personally rather ignore everything he says.
The guy have an ego and is wasting time building his own programing language for a game than most likely will flop, but hey, the guy is smart and have the money to spare and do whatever he wants, so be it.
EasyLowHangingFruit@reddit (OP)
Do you know by any chance where he gets his income from i.e. past games, consulting, or employment.
fauxmosexual@reddit
He authored Braid and iirc that was (one of?) the first ever Indie darlings sold on steam. It's a good game and very original and creative, but wouldn't stand out in today's marketplace. He did really well on sales, he thinks it's because he's a genius but he also got lucky with the buzz about being a rare indie developer and lack of competition on the platform back then.
Asyncrosaurus@reddit
As demonstrated by Braid Anniversary edition coming out last year and being a huge flop.
inokichi@reddit
Don’t quote me on this but I think he mentioned once in a live stream that he received loans off people he knows
HarpuiaVT@reddit
Probably past game: Braid and The Witness, specially The Witness
hiddenhare@reddit
Indie gamedev is a young art, and nobody in the world has mastered it yet. Most game code is a complex concurrent simulation which also needs to be very convenient to write, edit and delete - almost throwaway code. That's a unique challenge which requires specialised tools, and so there's plenty of room for a lone genius to change everything.
Blow is driven enough to be that genius, but he's not secure or open-minded enough. Performance tuning and eliminating complexity are his special talents, and he's staked his reputation on the idea that nothing else matters. This has made him blind to the benefits of anything which carries a performance or complexity cost, which has prevented him from engaging with most interesting recent developments in comp sci. It's really unfortunate.
DenverBill@reddit
TIL Jonathan Blow is a real person. I thought it was a weird autocorrect of "Joe Blow" and OP was tired of random people critiquing their skillset.
shifty_lifty_doodah@reddit
You should know off the top of your head about how long it takes to scan a terabyte from disk, add a billion numbers, lock a mutex, elect a leader, send a packet across the country, log a 1MB record on disk, etc.
And most importantly how to look all these things up.
EasyLowHangingFruit@reddit (OP)
Could you please expand a bit more on the things I should know by heart? Thanks in advanced!
shifty_lifty_doodah@reddit
No I cannot give you a professional education in a comment :). Buy a book. Read papers. I recommend the modern classic “designing data intensive applications” by Martin klepmann.
EasyLowHangingFruit@reddit (OP)
Thanks anyways, I still appreciate it!
EasyLowHangingFruit@reddit (OP)
This is very interesting! Thanks, I really appreciate it!
jessewhatt@reddit
being deep is less about what you actually know and more about your ability to come up to speed with certain skills easily, repeatedly going through the act of learning deeply increases your skill in being able to do so. You shouldn't be able to riff on every giga deep technical topic off the top of your head, but you should be able to come up to speed quickly if you need a certain skill for a certain task. That's the power of being a generalist, to not be intimidated by any technical task.
distinctvagueness@reddit
1 aws docs 2 splunk 3 uuid in requests responses 4 ExecutorService 5 spring acuator 6 profiler tool 7 GitHub actions 8 read some docs 9 jmeter or other spam tool
Jblow is "correct" abstractions cause some bloat but most performance issues for most jobs has nothing to do with rolling your own memory management or framework. Most problems are due to unnecessary round trips across the network ... hello microservices
Evinceo@reddit
Jonathan Blow needs some deep knowledge on how to het a project out the door instead of just talking about it.
DualActiveBridgeLLC@reddit
I guess we have different definitions of 'mission critical distributed system' since many of these technologies would not meet the definition of critical for many of my application spaces. When I hear mission critical I am thinking about human safety.
I would add
(1) a solid ability to diagram in an assortment of use cases
(2) writing mission critical requirements
(3) understanding of the relevant industry standards and certifications (FDA, SEA, etc.)
(4) Failure mode analysis and mitigation plans
(5) Redundancy
(6) "The big red button" and what happens when you hit it.
EasyLowHangingFruit@reddit (OP)
Oh yeah, sorry for the ambiguity. When I use the term "mission critical" I'm referring to parts of the system that support the very core business needs, in other words, what the company makes money with that can't under any circumstance go down.
PothosEchoNiner@reddit
I’m never learning gitflow
EasyLowHangingFruit@reddit (OP)
Good to hear! 👍🏼
chafey@reddit
Titles don't mean anything! Learn everything you can - that is how you add more impact and value to your employer. This is true for everyone regardless of their title
xzlnvk@reddit
I'm sure I'm forgetting some.
eyes-are-fading-blue@reddit
Dude half of these are specific to tech stack. A web developer who does front end doesn’t need to know IPC.
xzlnvk@reddit
Dude, I answered the question - stuff “every Senior SWE should positively have in the context of building and maintaining scalable, highly available, mission critical distributed systems”.
EasyLowHangingFruit@reddit (OP)
Good! Thanks, I appreciate it!
ZuzuTheCunning@reddit
I don't know who Johnathan Blow is, and at this point I think I'm better off not knowing if this is your takeaway from anything he says.
Gitflow, lol
EasyLowHangingFruit@reddit (OP)
Yeah, sure. Have a great day 👋
metaphorm@reddit
I don't think there's a single list of things that every Sr. SWE should know. I think what you end up learning is based on what you're interested in and what you've been working on. The field is too vast and too deep to learn everything. Instead of a specific enumeration of hard skills, I would point at a kinda vague cloud of core competencies and maybe more importantly, working habits.
Non-exhaustive list of Vague Core Competencies:
- understand the tooling of the ecosystem you're working in
- understand how to test your code. get good at writing automated tests.
- understand how to profile the performance of your code. use the appropriate tools for the job and be rigorous about what you measure and how you measure it.
- read Grug Brained Developer and really internalize everything in here. this is gold. complexity and cleverness are terrible for the long term health of code bases. your code should be as maximally stupid and simple as it can be while still meeting your requirements.
- develop an enlightened attitude w.r.t to technical debt and how godawful messy everything in software tends to be. learn how to work with code that is in many respects a dumpster fire. its YOUR dumpster fire now. better be able to work it.
Non-exhaustive list of important Working Habits:
- communicate early and often. communicate with your users. communicate with your team-mates. communicate with your managers. communicate with your customer support staff. figure out who all the stakeholders are and how to talk to them in a way that is productive. productive in this context means "people are able to express their needs and expectations with clarity".
- work incrementally. bias to action and bias to ship a smaller thing now rather than a bigger thing later. build bigger things incrementally by dividing the effort into chunks that can be implemented and released in phases.
- you're always "testing on prod" whether you know it or not. learn how to observe and monitor your production environments. this is your single best source of debugging information
- ask for help when you need it and ask the right people for it. nobody is an island. software is built by teams of people with sustained effort over time. asking for help (in the right way, of the right people) is a great way to build strong working relationships and to transfer knowledge internally. it also saves a lot of time. what might be a 6 hour slog for you would only be a 20 minute digression for someone more expert in that particular subsystem.
- make as big of a mess as you need to and not a bit more. accumulating tech debt is not really avoidable in any project that's "alive". you'll have to be strategic about introducing messes. it can be justified under some circumstances and don't be afraid to ship messy code now and clean it up later. just make sure you do go back and clean it up later.
EasyLowHangingFruit@reddit (OP)
Insightful. Thanks, I appreciate it!
Cachesmr@reddit
No one who knows what they are doing should listen to Jblow.
shozzlez@reddit
Who tf is Jonathan Blow?
Accurate-Sundae1744@reddit
Who is Jonathan Blow and why would I care what he thinks?
ninseicowboy@reddit
The fuck is GitFlow? Just use Git
wrex1816@reddit
I had to Google who that is. Am I supposed to follow and care what some guy online says? I meet enough big egos at work already.
Key-Alternative5387@reddit
J-Blow is a bunch of hot air. Decent games, but his persona is the 'I am very smart and that is my whole personality' type. Thankfully, that doesn't translate to anything that matters.
levelworm@reddit
Why do you cry? I don't give a fuck about things I don't care.
SpiritedEclair@reddit
I do systems, idfk distributed systems might as well judge me on my ability to fly.
SemaphoreBingo@reddit
I don't have a lot of respect for that dude and wouldn't take anything he says too seriously.
dash_bro@reddit
know the system that you use at work REALLY well. Seriously, no excuses for not knowing how YOUR system or feature or product works (depending on your scope)
tests, traces, logs and ability to pull and dissect what you need from these
step in and reduce complexity wherever possible at a process AND a code level
step out and let others fail and learn when possible. Nurture and direct, NOT handle it yourself.
There you go. That's about it
eslof685@reddit
knowing some things about the computer that all that runs on would help
xaervagon@reddit
The bulk of this is very pointed, very particular skills, for very particular roles. To just go through the list:
Nice to know the theory. It's not necessary unless you plan on working on them directly. Deploying on them doesn't count.
Every shop has their flavor of logging and management to go with it. If you have a degree, your school should have taught you good taste in logging.
Never had to use this, and I don't know anyone that has. That said, remote debugging is nice to have when you need it.
Unless you're doing embedded or HPC, knowing your IDE's basic debugger facilities (vars, callstack, cpu profiling) is usually plenty enough
Same as #4.
Good to have. Being decent enough at SQL in general is a good to have in most environments. Most modern DB GUI front ends like HeidiSQL and MS SQL Studio have nice little analyzers and visualizers that do the heavy lifting.
Never needed it. I don't mess around with build chains. A lot of that is in the hands of devops or under lock and key today. Maybe useful if you're building a hobby project or working a startup.
It's nice to know the theory behind the APIs. Most people using the APIs for these don't give a honk about what's going on behind the magic curtain as long as the API does The Thing. If you're in a startup environment, and need to hand configure stuff for clients, it's good to know.
I would be more concerned about basic unit testing and having goodnuff coverage on code.
The reality of it is, that it's the wild west out there in terms of tech and skills and every place and role is going to be a bit different.
If you want to be good in general have
cjt09@reddit
I like Jonathan Blow. I think he has interesting takes on software development and I enjoy his games.
That said, he’s pretty dogmatic about not relying on abstractions and trying to do as much as possible as close to the hardware as possible. Obviously you can be successful with this approach, but there are also some pretty big drawbacks, such as only being able to release one game every decade.
The vast majority of software development leans heavily on abstractions. Likewise, the vast majority of developers do not know about the intricacies of the JVM garbage collector or how their build system works under the hood. This can indeed lead to more bloated and slower software, but you’re also able to ship far more quickly. For most businesses, this tradeoff is worth it.
So don’t sweat it.
LNGBandit77@reddit
And some basic networking subnetting etc. basics.
originalchronoguy@reddit
This the domain of a SRE or Platform Architect that is embedded in a development team. Where they lend their expertise on adding hooks or building tooling to help a team.
throwaway264269@reddit
Strict-Soup@reddit
They should know how to answer vague questions that try to encompass an entire spectrum with .. wait for it....
"It depends"
ZombieFleshEaters@reddit
Why?