π Hey there, I am Gourav. I write about Engineering, Productivity, Thought Leadership, and the Mysteries of the mind!
I am thrilled to share that we are a 1000+ members community now. Canβt express my gratitude enough to each one of you reading this newsletter. π
I have worked in software companies of all sizes, from startups to Big Tech. I noticed some interesting aspects on how people think and build software.
Today I am sharing my key takeaways from working at companies of different sizes. These will be based on anecdotes of my experiences. I hope this will help you decide which company type is best for you.
1. Big Tech
Not all Big Tech companies are the same. I used to work in one such company and designed a technical solution involving distributed systems. It was roasted by other Senior and Principal Engineers in the review, to an unnecessary extent in the name of scale and safe rollout. Itβs not uncommon at a few Big Tech companies.
They used to pick a lot of nitpicks and ask questions out of context. They looked forward to a 5-10-year vision, while the feature needs to be shipped βquicklyβ as per PMsβ timelines.
This loop of "improve the doc", misaligned expectations, and pushback from sister teams leads to churn and process-driven burnout. They add up to over-skepticism and slow down the company.
But there is a strong reason why they are forced to follow such a suit. They operate at a huge scale. A small hiccup can cause a loss of billions of dollars and of customer trust built over years. And that is the reason, Engineers are paid top-notch at Big Tech.
My key takeaways are:
You will learn many best practices and understand how to operate systems at scale.
When you land impact, it will touch millions of customers across the globe.
Your payscale is exceptional.
You often end up coding relatively less and get stuck in processes and approvals.
Safe practices come with burnout. You might end up waiting to see the impact of your work for months or years in some projects.
2. Mid-Tier Companies
To clear up this vague definition. I am referring βMid-Tierβ to companies that are still on a growth trajectory. They also have a very high scale but not to the extent of Big Tech.
When I moved to mid-tier companies, I observed they move so fast and deliver results quickly by:
making a small testable net-new logic module, possibly behind a feature gate.
gathering early feedback by internal dogfooding and acceptance testing.
iterating back, fixing stuff, adding more features, and repeating.
avoiding unnecessary processes and consensus.
I had to unlearn many processes and coding practices. Most importantly, I had to unlearn 'asking for permission'. The autonomy and flexibility were great. They had the perfect blend of moving fast, showing impact quickly, and not overcomplicating. It positively blew my mind. On top of it, Engineers are paid really well.
But to enable teams to move fast, dedicated infrastructure teams build some abstractions. These hide the underlying concepts from product engineers. Systems could also go stale or become monolith pretty quickly.
My key takeaways are:
You will learn the art of a true 'Bias for Action' by coding the MVP quickly. This will deliver results faster and save the company's resources and money.
You seek consent over consensus.
Pay could be a little less than Big Tech, but mostly comparable.
You may slightly miss out a bit on best practices, processes, failure modes, and rollout experience at scale. System code becomes complex to manage relatively fast. But this is not always true.
Moving quickly without understanding the core dependencies could lead to shallow learning. This is especially true for some product-focused teams.
3. Startups
In between jobs, I also had an excellent opportunity to join a startup as Founding Engineer number #1. If done well, this role is sometimes matched to a CTO role.
I wrote the first set of APIs. I also implemented the build-and-deploy systems. I set a vision for the product and talked to potential customers. It was such a roller coaster ride. This journey was filled with a tremendous amount of learning in a short period. At the same time, the base pay was comparable to Big Tech but everything else was paper money.
But I was so burnt out after spending a major portion of my day and night contributing to the company. And I had some other personal commitments that I had to meet. I made a tough decision to part ways with the company.
My key takeaways are:
If you ever want to start your own company, working at an early-stage startup first is your best bet.
The surge of learning is incomparable. You learn deep tech in a short time. You also learn many different skills. This paves a path to C-suite leadership if you stick around.
The Gross Pay isn't great. But, it has a higher upside if you stay a long time and the company succeeds due to your deep contributions.
Your energy should match the commitments required at the startups. Also, the timing should suit your life. Otherwise, you wonβt do the job or personal life justice.
Burnout at startups is real. Defining boundaries between personal and work life is hard. You should make a conscious, informed, and hard decision before joining a startup.
Shout-outs π
Dumb Code Beats Smart Code - Donβt make the mistakes I made by
Feedback is a gift only if it is received well by
Design a Distributed Priority Queue by
The Role of a Technical Program Manager by
Feature flags are ruining your codebase by
Super Specific Feedback: How to give actionable feedback on work output by
3+1 strategies to track your achievements by
Letβs Connect π€
Sponsorship | Collaboration | LinkedIn | 1:1 Mentoring | Twitter
Gourav Khanijoe
First of all, Congratulations on achieving the 1000 milestone!
This is an enjoyable piece because it speaks truthfully and honestly about first-hand experiences in different working environments. Personally, I have experienced these differences in various roles, and it is always an enlightening experience to understand the various cultures that can propel my own professional career journey. Thanks for sharing your insight!
Either you are working at a startup and want to move to a Big tech company or you are in Big Tech companies and want to move to startups, then this is a must read!
This is a mature take on the the kind of jobs Engineers might want to work at. Everyone has different set of priorities in life and it is important to be informed about the work style.