Skip to content
View neilkakkar's full-sized avatar

Block or report neilkakkar

Block user

Prevent this user from interacting with your repositories and sending you notifications. Learn more about blocking users.

You must be logged in to block users.

Please don't include any personal information such as legal names or email addresses. Maximum 100 characters, markdown supported. This note will be visible to only you.
Report abuse

Contact GitHub support about this user’s behavior. Learn more about reporting abuse.

Report abuse
neilkakkar/README.md

Hi there, I'm Neil 👋

Website Linkedin Badge Twitter Badge

I work at PostHog, which is open source, which means I can now have Github stats and not feel disappointed:

neilkakkar's GitHub stats


I love learning in public, and I want to use this section to track what I did at work. I'm a big fan of data driven understanding - and I hope this log gives me a better understanding of what I'm getting done.

Things I'm doing: Click to expand!

December 2024

I took two months off in the middle to help recover.

Other than that, lots of progress on error tracking. I was much slower in July/August, but things seem to be picking back up after the break(s). Feeling better and can focus for longer, which is great :)

June 2024

We're now a team of 4!

I'm really excited about rewriting the flags service in rust (RFC - https://github.com/PostHog/product-internal/pull/587 ) - this has been amazing to work on. And its my excuse to learn rust as well.

Managing these four products has gotten to be a bit too stressful for me, partly my fault for not recognising the signs earlier and dumbly trying to power through. Oh well, lesson learned, and it was a harsh one. I stepped down as a tech lead and decided to switch teams and become an IC. Next up, session replay and error tracking!

March 2024

Alongside the usual, one big project this quarter has been revamping experiments, polishing them, making them much nicer, addressing most of the user feedback we've heard over the past year.

A frustrating feature flag incident (details here: https://github.com/PostHog/post-mortems/pull/1/files) had me kicking myself for not thinking of this failure mode earlier. I updated all SDKs and they are in a much nicer place with respect to resiliency.

December 2023

Some new features for flags, lots of bug fixing, and unblocking the team. We reduced down to a team of 2, which made juggling priorities a bit harder.

October 2023

Lots of survey fixes, new features for surveys, and quality of life improvements after user feedback. I'm proudest of getting rid of an opt-in step for surveys that was painful for users - rearchitecting our SDKs to make this just work increased conversion rate for users trying out surveys by 40%!!

August 2023

I'm writing this update more than a year later so I think I have the chronology a bit mixed up, but the fourth (and historically under-loved) product in our team comes to life: Early access features. Super useful, they're still used internally to allow users to opt in to feature flags. Very useful, 10/10 would recommend.

Personally, lots more bug fixes, and I've been focusing on integrating our 4 products now better into other PostHog products, like linking to recordings, easy actions in notebooks for flags and surveys, etc.

July 2023

We built a new product in our team: surveys!

June 2023

Lots of improvements to flag reliability, experiments, and cohorts.

We also setup pricing for feature flags. There was a very interesting technical challenge here around accurately counting number of requests that we'll price on. This number needs to be exact - it will be very wrong to overcharge users (which means we need to correctly handle race conditions between threads serving requests), and should not slow down the actual request itself. I think I ended up with a pretty elegant solution using redis time bucket sets - the current bucket can be filled up atomically, and a background job collapses all previously filled buckets with a lock to gather counts. We can't lock the current bucket because that interferes with all the threads adding request counts to it. More details in this PR: PostHog/posthog#15837

April 2023

I became the tech lead for feature flags, experiments. Lots to learn around how to manage effectively, and keeping up with my personal contributions as well. It's crazy how much small tweaks to team processes can boost efficiency, happiness, and the culture that evolves.

In retrospect, one of the most impactful changes I made was starting metric mondays to make our product decisions more data-driven. As soon as data became a part of everyday talks, and our revenue & churn numbers were on top of every team members mind, we made better decisions.

28 March 2023

New year, new offsite! This time, I had a solution: ChatGPT; and I was looking for a problem. We built a support bot to answer community questions - which has worked out surprisingly well.

Also, lots of tweaking around with the infrastructure, I've learned different ways pgbouncer can break. I wrote a blogpost about everything we learned trying to make flags reliable: PostHog/posthog.com#5546

28 February 2023

More feature flag optimisations, my favourite being with cohorts: PostHog/posthog#14272 - now, instead of relying on computed cohorts to evaluate flags, we convert cohorts into their definitions, and then use those in flags, so it uses the latest properties, irrespective of whether they are in the cohort yet or not.

This speeds things up as well, as we only need to go in one place to evaluate flags (the person properties database).

28 January 2023

Focus is back on feature flags, since they are the core of both experiments and features. We are mature enough with respect to features that a decent amount of people have started using them. This has brought up a new problem: Feature flags going down is a no-no. Not only does it affect our customers; but also our customers' customers.

So, make sure our flags are as resilient as possible: PostHog/posthog#13601.

Also, caching is hard.

28 October 2022

It's been a while since experimentation released, and we've learned what all mistakes we made. One big mistake I made was not allowing users to change experiment goals once the experiment started. I was worried about p-hacking, but more often than not, the issue was that people made a mistake setting up the experiment, and it was very annoying to restart the experiment just to change the goal, since you're losing all the data you've collected so far.

This month was all about fixing up these mistakes, polishing experiments up so we can learn the new ways things break.

We also spent some time thinking about the long term vision for our team: PostHog/posthog.com#4516

28 September 2022

More feature flag improvements. A big one was bootstrapping, which brings local evaluation to the client-side (in a way): PostHog/posthog-js-lite#24. You can initialise your libraries on the frontend with feature flags, which makes them instantly available.

28 July 2022

This month was about tackling the server-side libraries feature flag issues. I created a spec that simplified our work, since there was a standard document to replicate across libraries: PostHog/posthog#10459 (comment). This helped us review PRs quickly, and also helped us be faster for implementing, since you could blindly copy the structure, as long as you keep in mind language specific gotchas.

28 June 2022

The focus is coming back to feature flags. Specifically, there are a few problems that make them unusable on server-side libraries, and also for user flows (like authentication) where the user identity changes.

It was tricky figuring out how to add support for something like this, while not destroying performance, since this is a very sensitive endpoint. I ended up cleaning a lot of cruft on this endpoint to make this fast.

An explanation of the problem: PostHog/posthog#9547 The solution: PostHog/posthog#10196

28 May 2022

The next big thing to tackle is person on events: We are revamping all our queries to become scalable for billion event querying. This requires getting rid of joins as much as possible, and changing our data model a bit to support that. Here's a big overview of this: PostHog/posthog#9802 - this turned out to be a pretty massive refactor.

28 April 2022

The new project is support for complex filters in cohorts: not only can we freely combine them, but also added support for complex behaviour like figuring out if a user did an event multiple times / in a specific sequence to become part of the cohort. Github thinks this was my highlight PR for the project: PostHog/posthog#9462

28 March 2022

Lots of polishing on Experiments, the last 20% polishing takes surprisingly long. I've come to realise that frontend work takes a lot more time and effort.

We also had our offsite hackathon, out of which came Universal Search: The top searchbar on posthog now searches through everything to give a response.

4 February 2022

Automated Insights is the new hardd project, and I'm having a lot of fun remixing ideas: PostHog/posthog#8261. OpenAI is amazing: what would've taken me days to setup 3 years ago now took 30 minutes. 🤯. This is great for quickly validating & discarding ideas.

28 January 2022

This month has been amazing. Experimentation looks great, has kicked off well, users (atleast the ones we interviewed) love most of it, and we launched it to everyone on Cloud this week!

This project is different from Correlation Analysis, in the sense that it takes longer for feedback to arrive: Users have to actually finish running their experiments to give feedback on the later-half of the product: the experience while running & on ending an experiment. So, decided to pause improvement work on this for now, setup metrics & docs, and wait for users to use it, listen in to feedback, and then decide how to solve the problems that come up.

Super happy with all that got done this month (it's a LOT, with lots of ...experimenting):

image

7 January 2022

We hit a slight snag with Experimentation: Most users were away during Christmas, which made it hard to schedule feedback calls, which made it hard to iterate quickly. I switched strategies a bit, and now focusing on building out things we definitely need for Experimentation to be successful, sans feedback. Would've loved to validate these, but eh. Will do it as intervews start pouring in.

Went on a 2 week break myself as well, which was refreshing.

3 December 2021

Aaaanndd I'm back with a new Project! This time, we're targeting experimentation: PostHog/posthog#7418.

Just like last time, we want to get something working out this sprint. Ofcourse, I started with learning about what existing A/B test platforms do, building a model of why they do things that way, and then tweaking that model so it sits on top of PostHog's existing systems. That's what you see happen in the above thread^.

PostHog/posthog#7462

26 November 2021

Support Hero time again. Probably not surprising, but this is becoming more intense: there's lots more people in Slack asking questions, which means I'm stretched thin, but oh, such a nice problem to have.

Guess which week was Support Hero: image

19 November 2021

After the huge project, it's vacation time! Need time to recharge - it was intense, too many open loops that kept me thinking about work after work.

29 October 2021

I shipped Quant Analysis! While last time was just the MVP, this time we polished things up, iterated on user feedback, and went back to them to see if they were happy (yes, they were). This was absolutely brilliant.

I used to think the most complicated part of building a product was the software engineering. Now I think it's figuring out what to build.

15 October 2021

Wow, what a sprint! I finally started implementation on the huge-ass Quantitative Analysis Project. What's unique about this project is that I'm leading one for the first time. It started off like this: PostHog/posthog#5543

I was working closely with one other person, and we got an MVP out in week 1. This was faaaast! It allowed us to iterate quickly, gather feedback, and fix data issues quickly. With a product that depends on data being good, this was critical.

I wouldn't link specific PRs, because there were a shit-tonne

image

Interestingly, I spent a lot more time thinking about the problems to solve here, even after work (which didn't bode well for sleeping peacefully). At the same time, this allowed for some cool technical breakthroughs, where we could run correlations much quicker.

Finally, doing live user interviews was fun - getting feedback from actual users, reading between the lines, figuring out what they want, and then putting those ideas together was a fun challenge: PostHog/posthog#6474. The next sprint is going to be scary ambitious.

1 October 2021

Two weeks of working on Paths. We shored up the API, and I finally got my hands on the frontend code. Kea is an amazing library to work with.

One very interesting problem: Validating Graph Edges on Paths: PostHog/posthog#6041 (and linked PRs!)

17 September 2021

A (missed) Offsite, Support Hero, vacation to Mallorca <3

20 August 2021

I owned my first project! PostHog/posthog#5543

Apart from thinking hard about this, the regular sprint continues. Working on Paths - the new feature!

PostHog/posthog#5646

This week's been pretty cool, because I'm finally doing more of the ground-up startupy stuff: thinking through things from scratch, building PoCs, gathering results, and then finally building the product.

13 August 2021

Final sprint for Funnels, got the vaccine, got sick afterwards, didn't do much, except this one big bug fix for funnel breakdowns: PostHog/posthog#5655, PostHog/posthog#5538

6 August 2021

Remember how Support Hero was a lot of fun? (Week of 21 May, 2021). Time for round 2. A lot less overwhelming, as I knew a lot more about things (but still not everything).

Random bug fixes: PostHog/posthog#5486 etc. etc.

30 July 2021

More bug fixes, some tricky things to grasp, and finally dipped into other unknown areas. I follow a land-and-expand strategy: get really good at understanding one part of the system, then slowly expand from that "base" to understand rest of the system. This usually means that my work speed slows down, as I parse through all the new stuff.

A good way to do this is to pick up bugs at the edges of what you know. That's what I've been doing:

23 July 2021

Final sprint before Funnels meant lots of QA, lots of bugfixing, and lots of testing :) - I'm so tired now.

16 July 2021

Lots of gathering requirements, getting to the bottom of new features we want to implement: PostHog/posthog#5074 - and reminders to think from first principles.

9 July 2021

Who knew playing around with SQL, and generating interesting queries could be so much fun? This week was more dakka: more add ons, more functionality to the basic funnel APIs. Some clever refactoring + testing mechanisms, that I enjoyed setting up

2 July 2021

Some big funnel improvements

25 June 2021

I was getting pretty comfortable with my role, and that seemed like the best time to switch teams 😂. Purely co-incidental, we shifted focus, and I've been writing wonderful SQL this week. Damn, this is SO MUCH FUN. This week (and hopefully the coming few weeks, really want to brush up on my querying skills). This has been very helpful: https://pgexercises.com/

18 June 2021

Finishing up new processes for the Plugin Developer Experience, plus excellent docs.

11 June 2021

Well, plugin installation is deprioritized for now. New focus: plugin development experience! Lots of time spent thinking about how the documentation should look like, what workflows should the code promote, and what feels confusing.

4 June 2021

Thinking about a big project, and learning enough about the interacting systems to design a decent solution can be hard! Really looking forward to finishing the plugin installation step.

28 May 2021

Getting comfortable with the codebase, starting to focus on reviewing others' code. It's interesting to try and model how new changes would affect the existing code. Further, this helped uncover my blindspots - glad I started this earlier than later!

21 May 2021

I was Support Hero this week! It's... intense! Lots of user issues that I first have to learn about myself, and then solve. This took a surprisingly long amount of time, but was very worth it: it helped me see where actual users of PostHog get stuck.

It's funny how this appears to be the least productive week so far, but I felt I got much more out of it, vs the past 2 weeks. I ought to do Support Hero more often than the usual schedule, if possible.

14 May 2021

7 May 2021

Week 1 at PostHog!

Pinned Loading

  1. QuickReps QuickReps Public

    https://neilkakkar.com/quickreps.html

    Swift

  2. medium-markdown medium-markdown Public

    An NPM package to convert Medium posts to Markdown

    JavaScript 6 1

  3. Encryption Encryption Public

    A simple encrypter and decrypter for sending and recieving coded messages.

    C++ 1

  4. highly-exporter highly-exporter Public

    Export all highlights out of Highly, since it's shutting down.

    JavaScript