A post on Reddit recently caught my eye — someone built an entire brand around a domain they thought they'd purchased, only to discover they never actually owned it. The domain was bundled with a website builder subscription, and when things went sideways, they had zero control.
This hit close to home. Early in my career, I registered a domain through a hosting provider's "free domain" deal. When I tried to transfer it two years later, I learned the hard way that "free" meant "we hold the keys." That experience changed how I think about every layer of my web stack.
So let's compare two approaches: the platform-bundled model (where one provider handles your domain, hosting, and tools) versus the own-your-stack model (where you control each piece independently). We'll cover domains, hosting, and even analytics — because ownership matters at every layer.
The Domain Problem: Bundled vs. Independent Registration
When a website builder offers a "free domain" with your subscription, what you're often getting is a domain registered in their account. You might be listed as the contact, but the registrar account — the thing that actually controls the domain — belongs to the platform.
Bundled Domain (Platform-Managed)
# What your "domain ownership" often looks like with bundled platforms
registrar_account: platform-corp
domain: your-cool-brand.com
registrant_contact: you@email.com # you're listed here
admin_contact: platform@corp.com # but they control this
transfer_lock: enabled # good luck moving it
auto_renew: tied_to_subscription # cancel the plan, lose the domain
Independent Registration
# What actual domain ownership looks like
registrar_account: your-personal-account
domain: your-cool-brand.com
registrant_contact: you@email.com
admin_contact: you@email.com # you control everything
transfer_auth_code: available # move it whenever you want
auto_renew: your_payment_method # independent of any other service
The difference is stark. With independent registration, you can point your domain anywhere — swap hosting providers in an afternoon, set up a staging subdomain on a different platform, or hand the domain to a colleague. With bundled registration, you're asking permission.
Registrar Comparison: Where to Actually Register
Here's how the major independent registrars stack up:
- Cloudflare Registrar — Sells domains at wholesale cost with no markup. No upsells, transparent pricing. DNS management is excellent. My current go-to for new projects.
- Namecheap — Solid independent registrar with competitive pricing. Good UI, easy transfers. Has been around long enough that I trust their stability.
- Porkbun — Surprisingly good pricing and a clean interface. They've earned a loyal following for being straightforward.
- Google Domains — Was a great option, but Google sold its domain business to Squarespace in 2023. Existing domains were migrated. Worth noting if you're still on the Squarespace registrar side — you still own your domain, but the experience changed.
Any of these will give you a registrar account where you hold the auth code and you control transfers.
Hosting: Same Ownership Principle
The domain lesson extends to hosting. If your site, domain, email, and analytics all live under one platform login, a single account suspension kills everything.
A more resilient setup separates concerns:
# A typical own-your-stack DNS configuration
# Domain registered at Cloudflare, pointing to your hosting
# A records for your main site (hosted on a VPS or PaaS)
your-cool-brand.com. A 203.0.113.10
# CNAME for www
www CNAME your-cool-brand.com.
# MX records for email (separate provider)
your-cool-brand.com. MX 10 mail.fastmail.com.
your-cool-brand.com. MX 20 in2-smtp.fastmail.com.
# TXT for analytics verification (self-hosted)
_verify TXT "umami-verify=abc123"
Each service is independently replaceable. Your email doesn't die because your hosting went down. Your domain doesn't vanish because you cancelled a website builder.
Analytics: You Should Own This Data Too
Since we're talking about owning your stack, let's look at analytics — another layer where developers often hand over control (and their users' data) without thinking twice.
Google Analytics is the default, but it raises real privacy concerns and you don't control the data. Here are three privacy-focused alternatives worth comparing:
Umami vs. Plausible vs. Fathom
| Feature | Umami | Plausible | Fathom |
|---|---|---|---|
| Self-hosted option | Yes (free, open source) | Yes (open source) | No (cloud only) |
| Cloud/hosted option | Yes (paid) | Yes (paid) | Yes (paid) |
| GDPR compliant | Yes — no cookies, no personal data | Yes — no cookies | Yes — no cookies |
| Script size | ~2KB | ~1KB | ~2KB |
| Dashboard complexity | Simple, clean | Simple, opinionated | Minimal, focused |
| Custom events | Yes | Yes | Yes |
| API access | Yes | Yes | Yes |
| Pricing (cloud) | Free tier available | Starts at $9/mo | Starts at $14/mo |
Umami stands out for developers specifically because of its self-hosted model. You run it on your own infrastructure, which means you own every byte of analytics data. It's a Node.js app backed by PostgreSQL or MySQL — dead simple to deploy:
# Docker Compose for self-hosted Umami
# Clone the repo first: git clone https://github.com/umami-software/umami.git
docker compose up -d
# Default login: admin / umami
# Change this immediately after first login
# Add the tracking script to your site:
# <script defer src="https://your-umami-instance.com/script.js"
# data-website-id="your-website-id"></script>
Plausible is my recommendation if you want a hosted solution with an open-source escape hatch. Their dashboard is genuinely pleasant to use, and their self-hosted Community Edition means you're never locked in. The script is tiny and won't slow down your site.
Fathom is the premium option — polished, reliable, but cloud-only. If you want zero maintenance and don't mind paying more, it's solid. But you can't self-host it, which breaks the ownership principle we're talking about here.
For a developer running a personal site or a small SaaS, I'd lean toward Umami self-hosted. The setup takes maybe 20 minutes, and you never worry about a vendor changing their pricing or terms.
Migration Checklist: Going from Bundled to Independent
If you're currently in the "bundled" situation, here's how to untangle things:
- Domain: Request the transfer auth/EPP code from your current provider. Register an account at an independent registrar and initiate the transfer. This usually takes 5-7 days.
- DNS: Before transferring, document every DNS record you currently have. Screenshot it. Some platforms make this hard to export on purpose.
- Hosting: Set up your new hosting independently. Get the site running on the new host before you change DNS.
- Email: If your email is bundled too, migrate to an independent provider first. Losing email access during a domain transfer is painful.
- Analytics: Drop in Umami or Plausible. You'll lose historical data from Google Analytics, but honestly — were you even using that data?
The Real Tradeoff
I'll be honest: the bundled approach is easier. One login, one bill, one support ticket when things break. For a non-technical person building a portfolio site, it might be the right call.
But for developers? We should know better. The convenience of bundling comes at the cost of control, and that cost only becomes visible when something goes wrong — a price hike, a policy change, a suspended account, or discovering you never owned your domain in the first place.
The own-your-stack approach takes an extra hour of setup. In exchange, you get the ability to swap any component without rebuilding everything else. That's not paranoia — that's good architecture.
Same principle we apply to our code. Loose coupling. Clear interfaces. No vendor lock-in at the infrastructure level.
The Reddit poster learned this the hard way. You don't have to.
Top comments (0)