Host a website for less than $9 per year.
I bought my domain, kalebreynolds.com, about 13 years ago with no plans to use it other than to lay claim to it, it is my name after all. With that, I threw up a VERY simple page consisting of just my name in the center. I did this for a few reasons, but mainly because I wanted to host it in the cheapest way possible. Back then my research landed me on nearlyfreespeech.com, which at the time was by far the cheapest way to go. They charge on a pay as you go model, and at the time for my site, it was insanely cheap. For $15-20/year I could register a domain and host a single static HTML page with no surprises. Couple this with the fact that I was able to take advantage, and still do, of Google's Google Apps for Domain (Gmail for Domain back then) for free and I figured I had a winning combination. I ran with this setup until this week when I went to setup a domain/website/email for a side project my Wife is working on.
Fast forward 13 years and quite a bit has changed, for one nearlyfreespeach.com is significantly more expensive than it used to be. I don't blame them, they summarize the reasons for one of their price hikes in a post they sent to all their subscribers here. It was a gradual change, and until I looked I didn't realize how much I was paying for their service. Gmail for domain is no longer free, this site is thankfully grandfathered in, and at $72/year hardly worth it for what my Wife is doing. Add everything together and it began to seem like I would be on the hook for almost $100/year for a website. That isn't unaffordable but compared to what I thought I was paying it was just too high.
With that, I set out to find a way to host my Wife's website, and in turn this one, for the cheapest way possible.
To be considered a viable solution, I had a set of minimum criteria for this project.
- The domain had to be a custom top-level domain. No free hosting services would work. kalebswifescoolwebsite.geocities.com doesn't exactly have a professional ring to it.
- Had to be scalable and secure. If, by chance, we did get a reasonable amount of traffic it should be able to handle it.
- The ability to send and receive emails from the top-level domain. Nothing bugs me more than to see @gmail.com or @aol.com on a contact page of a website.
- Some type of analytics, what would be the point of getting 10 hits per day if we couldn't brag about it.
- No Ads.
- Easy enough for my Wife to make the day to day updates to it.
- Had to be as cheap as possible.
With my criteria set I went to Googling, and below is what I came up with. I am not going into the specific details of setting each piece up, as there are already many guides for each step out there and I don't make it a point writing a rehash of information already available. However, in all my searching I could not find a guide pointing out the cheapest way to do this, and that was worth sharing.
Domain Registration/DNS Provider: Cloudflare
Knowing that one cost I wouldn't be able to get around is domain registration I searched out the cheapest option out there, and this turned out to be my only expense in this project. You can get $.99 domains from several of the usual suspects online, but there is always a catch of being tied to a hosting plan that would cost more over the year than just forking over for registration. Cloudflare offers registration for the wholesale cost, so over a year, they are by far the cheapest I could find. For a whopping $8.03 I registered the domain with Cloudflare. This included private registration and an ICANN fee. The caveat is Cloudflare needs to be your DNS provider, which for this project turned out to be an advantage as we need a DNS provider, they are one of the best in the business at that, plus they will be used later on to help keep costs low. A win-win for my budget.
Website Hosting: Amazon AWS - S3
When I started this project I knew I wanted a static HTML site. This would reduce the complexity, the cost to host it, and make it inherently more secure. Getting my wife to manage a static HTML site was the only concern, so I made sure to solve that before I decided on S3 and will address that a bit later in this post. Amazon allows you to host a static site straight out of an S3 bucket under their free tier plan. Setting it up was easy enough, following the guide they provide. Their guide goes into some extra steps about using Cloudfront for a CDN and using Route 53 for DNS, but I didn't do any of that. All I needed was a delivery system for my static HTML files, as I was already using Cloudflare for my CDN and DNS. Further not using those services from Amazon took away any danger I would max out the AWS free tier unless my site got a crazy amount of hits, which let's be honest, it won't. The only tricky part here is you have to use CNAME records to route traffic to S3, which isn't allowed at the root of a domain. I was able to get around this by using a Cloudflare page routing rule, again free, to route all requests to domain.com to www.domain.com that points to AWS.
Content Delivery Network: Cloudflare
The CDN portion of this was a key element in keeping my site fast and costs super low. Using Cloudflare's free plan and proxying my site through them I can keep the calls to the source files on S3 to a minimum. This goes a long way in ensuring I won't push my usage over the AWS free tier and keep the site free as each call counts toward my usage. Setting this up is about as simple as it gets, a single click in the Cloudflare interface, and all the heavy lifting is done.
Content Management System: Publii
This was honestly my biggest concern for the entire project. Spinning up a WordPress site, or using a website in a box, like Squarespace, Wix, etc.... was very tempting. However, with my goal of making this thing as cheap as possible, that was not an option. After much searching, I found Publii, basically a free CMS that you run locally on your desktop. Once you add content Publii renders the page and generates static HTML files, more importantly, it will publish those files directly to an S3 bucket. Publii is super easy to use, does all the hard work for you, and has an editor anyone can use. In fact, for testing, I switched this website to use it and honestly am very impressed.
Email: ImprovMX & Gmail
Email hosting turned out to be one of the more costly things I had to consider initially. I love Gmail, but in my opinion, if you take the time and effort to buy a custom domain and set up a custom website, having an @gmail.com email address on the contact page makes you look lazy. This is where I cheated a bit because my wife is using Gmail. Using ImprovMX I can forward emails sent to [email protected] to [email protected]. This is as simple as registering an account with ImprovMX and setting your forwarding rules. Once done add the MX records to Cloudflare and send a few test emails. For sending email we landed on using the built-in feature of Gmail to send as an alias, now any email sent from [email protected] gets delivered as [email protected]. Professional and easy with an interface my wife is familiar with.
Analytics: Google Analytics
This is the old tried and true standby, used by most and honestly the best. Google's entire business is tracking what people do on the web, so using them to track what people do on your website just makes sense. Adding their tracking code as a custom header on Publii is simple and it's truly set it and forget it.
Conclusion
I hope this helps someone host a website for less than a cup of grungy diner coffee per month. I did not get sponsored by anyone suggested above, and never will. It is just the cheapest way I found to do this properly, and $8.03/year is pretty damn cheap.