12
7 Comments

The tech stacks of 20+ businesses and why founders chose them

Ever wonder what tech stacks other founders are using and why they use them?

Let's take a look under the hood. 👇

Indie hacker tech stacks

👤 Jay Tan of Zylvie:

I've used Python/Django since 2011. For the front end, I use vanilla Javascript and Bootstrap. I deploy on an Ubuntu VPS on Digital Ocean. I see no reason to switch or even explore other options when it comes to my stack, as they have served me very well for many years.

Django, Bootstrap, and Javascript are free. I think my Bootstrap template cost me $40 from Envato, but it's well worth it, as it allows me to build very quickly without having to worry about design, with ready-made template pages and components. I get a lot of compliments for the design of Zylvie — little do they know, I didn't even design it, but merely stitched stuff together. As for my server costs, my Digital Ocean droplet costs me $12/mo.

As for why I deploy on a VPS like Digital Ocean, it's because I want to be able to re-deploy my site anytime I need to on another server. I want to be in control and reduce platform dependency. I've heard scary things about PaaS solutions like Heroku, and I want no part of it.

👤 JT of No Code Founders:

  • Mailerlite (newsletter)
  • Bubble (main site)
  • Ghost (blog)
  • Podia (courses)
  • Superhuman (email)
  • Sendgrid (transactional emails)
  • Canva (graphics)
  • Midjourney (blog images)
  • Plausible (analytics)
  • Loom (recording)
  • Calendly (meetings)

Bubble allows me to create totally bespoke features exactly how I envision them. It's a little more complex than other no-code tools, so I keep the rest of the stack as simple as possible. Mailerlite is very easy to use and has really advanced features. Podia and Ghost take care of my blog and course needs on autopilot. Canva and Midjourney both simplify my image creation, and Plausible is much easier to navigate than Google Analytics. Then my back-office tools like Calendly and Loom are all about saving time.

👤 Mac Martine of The SaaS Bootstrapper:

My career started as a developer, but I am probably the least techy developer I know. I do not keep up with new tools or languages. I stick with what I know and what I'm fastest with. I've been using Ruby on Rails since 2007 or so and I'm incredibly fast with it and I love it, so I pretty much use that exclusively. And Postgres is my go-to database.

I recently migrated my current apps from AWS to Render and I wish I had done that long ago. It saves me so much time and has even reduced my server costs quite drastically. Our Render bill for the Rails app, database, background workers, Redis, and cron jobs is around $160 a month, and we have hundreds of customers running on there.

All my coding happens in Vim. I'm a minimalist at heart.

👤 Jason Leow of Jason's Plugins for Carrd:

I use plain vanilla Javascript and some Vue for my Carrd plugins, but those aren’t full-stack apps to start with.

The only full-stack app is Lifelog, with this setup:

  • Nuxt (frontend)
  • Bulma (CSS library)
  • Strapi (backend CMS)
  • Postgres on Heroku (database)
  • Stripe via Payhere (payments)
  • 3rd party APIs like Robohash avatars, ImgBB, and html2canvas for specific functionalities
  • Sprinkled Google Sheets for banner updates
  • Other no code tools like Google Forms etc

The more I develop for Lifelog, the more comfortable I get with this tech stack. I almost feel like this could be the one tech stack to stick to…

But yet there’s a bunch of things I don’t enjoy about this stack. Like the incessant updates, the build step, the tooling required.

Maybe what I should do now is to just ship based on the tech stack I know. But learn the new tech I want to learn along the way and slowly replace the new tech with old with my tech stack, eventually replacing the entire thing. Source

👤 Jim Raptis of BrandBird:

Experimenting with a new tech stack for my upcoming product:

  • Lemon Squeezy (payments)
  • Supabase (auth & database)
  • Serverless Vercel (functions)
  • Next.js (frontend

My regular SaaS stack is:

  • Stripe
  • Vercel
  • Next.js
  • Express.js
  • MongoDB

But I wanted to eliminate friction.

The serverless stack (hopefully) will allow me to ease the backend "headaches" and iterate quicker.

And Lemon Squeezy will ease my accounting since it's a merchant of record and I want to test one-time purchases for my new product.

Then, if I need to implement SaaS pricing in the future, migrating to Stripe won't be an issue. Source

👤 Courtland Allen of Indie Hackers:

  • Ember.js
  • Firebase
  • Node.js
  • Hosted on Render and Google Cloud

👤 Tony Dinh of TypingMind:

Here is the tech stack I use for all of my products:

Frontend:

  • ReactJS
  • NextJS
  • Tailwind CSS

Backend:

  • NextJS
  • ExpressJS
  • pm2 (npm install pm2)

Database:

  • MySQL (relational data)
  • Redis (key-value data)

Services:

  • Sentry (Error reporting)
  • Pirsch Analytics (Web Analytics)
  • Namecheap (Domain)
  • Cloudflare (DNS)
  • GitHub Pages, AWS S3Static (hosting)
  • DigitalOcean (cheap), AWS EC2 (Servers)
  • Paddle (Payment)
  • Mailgun (Sending email)
  • Fastmail (Email forwarding)
  • GitHub Actions (CI/CD)
  • AWS Lambda (Serverless) Source

👤 Marc Louvion of ShipFast:

I use the same tech stack for all my products:

  • Javascript
  • React
  • NextJS
  • Tailwind
  • daisyUI
  • MongoDB
  • Stripe
  • Mailgun

👤 Uri Seroussi:

Depending on the project, I like using:

  • Next.js/SvelteKit (Frontend/serverless backend)
  • Typescript + Zod (JavaScript type safety and schema validations)
  • Tailwind / MUI (Styling frontend)
  • Auth.js (Authentication)
  • Playwright (Testing)
  • MongoDB Atlas (Database)
  • AWS S3 (Storage)
  • Vercel (Hosting and deployment)
  • Railway (Hosting any extra Nodejs codebases)

Pros:

  • Everything is pretty much JavaScript.
  • Cheap. Shouldn't cost anything while building and initial scaling.

Cons:

  • I don't know lol. I'll know when I find something else I like better or when something here doesn't hold anymore. 😅 Source

👤 John Yeo:

  • Next.js (frontend)
  • Golang (backend)
  • Postgres/MongoDB (DB)
  • Digital Ocean (hosting)
  • Ant Design (styling)

Been using NextJS a lot more recently, and love the SSR feature. Only issue I face with it is the need for dynamic importing of certain modules, which can sometimes be annoying. But other than that, a really frontend framework.

Golang is amazing for backend dev. Really love the way it handles concurrency, and the nature of interfaces and types. The code can be a bit long sometimes (compared to Python and NodeJS), but definitely feels very solid for any web app. I am starting to use NodeJS a bit more because I'm trying to ship faster, though! Source

👤 Alberto Gimeno of Ground Control:

  • Next.js (frontend)
  • Cloudflare (API) — it is faster in my tests than Vercel edge functions and it has some interesting APIs that I wanted to use.
  • PlanetScale (DB)
  • For background jobs, I'm evaluating both inngest and temporal cloud as orchestrators and they run in Railway.
  • Postmark (sending emails)
  • Datadog (gathering logs from Cloudflare and Vercel)
  • GitHub (code hosting and CI/CD)
  • instatus.com (status page)
  • Stripe (payment)
  • Everything is written in TypeScript. Source

👤 Bruno Bernardino:

I like to keep things simple, thus I've got mostly static sites with vanilla JS when it's a "free tool" or "service" that can run entirely in the browser/ When it's not, it's running under a small Digital Ocean droplet with TypeScript in the backend and frontend (transpiled in real-time via Deno), without any frameworks or unnecessary dependencies. All with a docker-compose file for the main thing and dependencies, proxied by Caddy in order to have a few different apps running in the same server. And with automatic SSL. These allow spikes of hundreds of pageviews per minute and a dozen of paying customers across a few apps/websites.

There's honestly nothing I dislike about it. It's all pretty stable, fast, and cheap. A couple of servers with backups all come to under $35/mo for ~20 served apps. I get automatic tests and deploys with CI (I use GitHub for OSS, but for non-OSS I have my own Gitea server handling CI too). And it's faster and more stable than when I used Vercel, AWS Lambda, Render, or Deno Deploy, though definitely more expensive.

Keep in mind that if you ever achieve or compare with "big scale" startups, it's highly unlikely you'll see anything that's not AWS or GCP via k8s nowadays, for a multitude of reasons not worth mentioning here. Source

👤 Aviv_Shvitzky:

  • Next.js (Fullstack)
  • Prisma + CockroachDB (Serverless database & ORM)
  • Tailwind + Preline (UI)
  • Tanstack Query (Global state)
  • Vercel (Serverless)

React has the biggest adoption. Whatever tool I need probably exists for React and has a React integration, or was made just for React. Like "React Email". Next.js is the best react framework.

Prisma makes it easy for me. Tailwind is by far the best design library, hands down, no competition. Tanstack Query has changed the way I consume API data, and I will never be able to look back.

All of these tools have big communities, and their future seems very stable. None is bleeding-edge or experimental. Source

👤 Tair Asim of nextbuild:

My preferred tech stack for a new web app in 2024:

  • Next.js (app)
  • Supabase (auth + db)
  • shadcn (UI)
  • Lucide (icons)
  • Hook Form (forms)
  • Stripe (payments)
  • Resend (tx emails)
  • zod (validations)
  • Sentry (bug tracking)
  • Posthog (analytics) Source

👤 JR of Beam Analytics:

My go-to tech stack for new projects:

  • Vercel/Next.js (frontend)
  • Render (API)
  • Tinybird/ClickHouse (OLAP)
  • Supabase (DB/Auth)
  • Beam Analytics (Web Analytics)
  • Tailwind CSS (CSS)
  • Loops (Email)
  • Headless UI (Accessibility) Source

👤 Csaba Kissi of Invoice Generator:

  • HTML, Tailwind CSS, JavaScript, VueJS, InertiaJS (Frontend)
  • PHP + Laravel (Backend)
  • NodeJS + Express (Small APIs)
  • MySQL/Postgres (Database)
  • VSCode with Git Lens (Code Editor)
  • Vercel, Hetzner (Cloud)
  • Figma (UI/UX) Source

👤 Zeno Rocha of Resend:

  • Supabase (Database)
  • Better Stack (Monitoring)
  • Svix (Webhooks)
  • Resend (Email)
  • Mintlify (Docs)
  • Code (Editor)
  • Fira code (Font)
  • Cron (Calendar)
  • Notion (Notes)
  • Raycast (Launcher)
  • Browser Company (Browser) Source

👤 Sharyph of AiROAD:

  • Stripe (Payment)
  • Notion (Idea)
  • Zoom (Sales call)
  • Gumroad (Selling)
  • Calendly (Call booking)
  • Canva (Graphic Design)
  • Elementor (Page Builder)
  • Discord (Communication)
  • ConvertKit (Email marketing) Source

Tech stack tips

👤 Alexander Isora of Unicorn Platform:

Here's how to pick your tech stack.

The frontend world is changing fast, so the approach here is dead simple: Pick any of the most popular tech. You can find the list of top frameworks here.

Backend is more stable. So the choice here depends on a personal language preference.

  • Like simplicity? Go for Python with DJango or Flask.
  • Over 30 years old? PHP + Laravel.
  • Play Fortnite? Go Go.
  • Enjoy coding in JavaScript? Use Express.
  • You can see sharp? Pick up C#.
  • You like pineapple pizza? Go Java.

👤 Arvid Kahl of The Bootstrapped Founder:

The best tech stack is the one you already know. Source

👤 Jason Leow of Jason's Plugins for Carrd:

One recurring pattern I see from indie hackers who are fast, prolific shippers is that they just use the same tech stack. Every. Single. Time.

  • Pieter Levels with PHP and jQuery
  • Jon Yongfook with Rails and jQuery
  • Danny Postma with Nuxt

It’s a simple and straightforward approach – just use the tools you’re the most familiar with, that you’re good at and can work fast with. The tech doesn’t matter.

Most of the time customers don’t care, unless your customers are devs themselves using the code (like a boilerplate).

I like this approach. But I realize I’ve not really honed in on a tech stack to be able to do it. Source

👤 Marc Louvion of ShipFast:

I never change my tech stack.

So I can ship faster.

Customers don't care about the invisible. Source

👤 Joe Clark:

Nobody cares about your tech stack.

They just want their problems solved. Source

👤 Santiago Valdarrama of ml.school:

I wanted to build a simple website for my course and bought a template. I wanted to save time.

I was surprised to read the template used the following tech stack:
• Next.js
• Tailwind
• Headless
• React
• TypeScript

Holy Moly! This is supposed to be a simple site. I wanted to finish it today.

I spent 2 hours. I couldn't make any progress. I threw the template into the trash and started writing vanilla HTML/CSS.

It's ridiculous how much people like to overcomplicate their lives. Source

👤 Jay Tan of Zylvie:

Django is a mature framework and has a shit ton of documentation, packages, plugins, etc. available. It's also well-maintained and state-of-the-art. I'm most familiar with it and thus can build the quickest with it. There's no special reward for building with the newest, coolest languages or frameworks -- all you'll be rewarded with is more wasted time when you could have done it faster using what you have already mastered.

👤 Michael Sitver of Letterjoy:

It doesn't f__ing matter. Just learn something. It's easier to learn new languages after you master one. The switching costs are lower than the opportunity cost of not starting now.

Learn JS (and Node). It works server side. It works for front-end. You can build apps, websites, APIs, and random scripts. And it's not super hard. Source

👤 Jack Forge of The Collective:

You shouldn't judge people based on their tech stack. 🤝 Source


Subscribe for more how-tos, roundtables, and interviews with people in the thick of it.

posted to
Icon for series The Boot's Trap 🪤
The Boot's Trap 🪤
on November 24, 2023
  1. 1

    I would say if you want to rank your website on Google SERP, just follow the basic SEO and don't use any blackhead technique to rank for longer period. Here you can check my site i am ranking on 1st position on my main keywords.

  2. 1

    Love seeing Digital Ocean mentioned here! They're my go-to for spinning up little experiments and they've proven to be remarkably stable over the ~4 years I've been a customer.

    I run my own current project from a teeny tiny droplet that has given me absolutely no issues so far.

    I'm a big Golang fan too, so shout out to John Yeo for choosing it. It really is a great back-end language all-around if you're ok reinventing a few wheels here and there. Maintenance is super simple (or nonexistent) once you have working Go code though, so it all adds up in the end.

  3. 1

    Thanks for including my invoice generator, James! Appreciated!

  4. 1

    Thank you for providing this comprehensive assessment of tech stacks. It's always interesting to see what other builders are using!

  5. 1

    Its too informative for me. I am excited to add these on my personal website.

  6. 1

    Love this! Thanks for sharing this in-depth review of tech stacks. Always fun to know what other builders are using!

  7. 0

    For organic traffic and SEO research I would like you guys to try out my tool which will automate keyword research.

    The tool will go tru thousands of keywords which is related to the your targe market and target customer and then come out with the best 100 keywords to target for.

    The analysis is done based on the traffic, trend, difficulty and intention data.

    It will help you make SEO research 100x quicker . If you want to try it out checkout decentool.com

Trending on Indie Hackers
Meme marketing for startups 🔥 User Avatar 11 comments After 19,314 lines of code, i'm shutting down my project User Avatar 1 comment Need feedback for my product. User Avatar 1 comment 40 open-source gems to replace your SaaS subscriptions 🔥 🚀 User Avatar 1 comment We are live on Product Hunt User Avatar 1 comment Don't be a Jerk. Use this Tip Calculator. User Avatar 1 comment