title: | We migrated our blog to Val Town in a day, and you should too |
---|---|
description: | This very blog that you're reading right now is now hosted on Val Town |
pubDate: | 2025-04-07T00:00:00.000Z |
author: | Steve Krouse |
We migrated our blog to Val Town 🥳
We completed this migration in about one day of work. Now our deployments happen instantly (~100ms), and we've greatly simplified our blogging stack.
Before | Now | |
---|---|---|
Rendering | Astro | React |
Version control | GitHub | Val Town |
Text editing | local editor | Val Town |
Deployment | Cloudflare Pages + GitHub | Val Town |
Hosting | Cloudflare Pages | Val Town |
CDN | Cloudflare | Cloudflare |
Maybe! It depends on your constraints and what matters to you. We care deeply about:
- Tight feedback loops
- Simple, browser-based workflows
- A fast migration
We also care deeply about dogfooding, but unless you're us – and unfortunately most of you aren't – that one doesn't apply to you.
- Val Town Projects are beta software, so you'd be on the cutting-edge alongside us. We're coming up with patterns that you'd get for free from a mature blogging tools like Astro and Cloudflare Pages.
- Val Town doesn't yet have pull-request comments like Github does.
- We don't have good workflows for bundlers or build steps, so it's hard to use anything that requires vite, etc.
We at Val Town are obsessed with tight feedback loops.
"Creators need an immediate connection to what they're creating."
– Bret Victor, "Inventing on Principle"
In some ways, this singular comittment to tight feedback loops is what seperates Val Town from all other code hosting & deployment platforms. We believe that you should be able to iterate directly in your production environment, not iterate locally, then deploy, then wait minutes to see how things look live.
In Val Town, a save is a deploy, and it happens in about 100ms. We go to great technical lengths to make this possible. This means no waiting minutes to see what your post looks like live. And this goes for branches too. Every edit of every branch is instantly deployed in a branch preview.
Val Town lets you use fewer tools. It replaces:
- your local text editor,
- git + GitHub for version control
- whatever you use for deployment and hosting, Cloudflare, Vercel, Render, Railway, Heroku, Digital Ocean, Hertzner, etc
Simpler, browser-based workflows are particularly important for casual contributors, such as less technical folks on your team or contributions from strangers on the internet. Val Town is a single place for code to be edited, versioned, collaborated on, and deployed. No need for anyone to install or use git, clone the repo locally, install programming languages or dependencies, or use a local text editor.
For example, if you wanted to submit a fix a typo in this blog post that you're reading right now:
- Sign up to Val Town
- 'Remix' this project
- Make your edit to this file
- Type cmd+enter, to see the changes live on your remix
- Send us a pull request
To be fair, the flow to editing a markdown file in a Github repo is fewer steps than this – and we do plan to make our flow as simple as theirs – but what we bring to the table is step (4), the ability to view exactly what your changes will look like when merged into main. This isn't an option (for good security reasons) for outside contributors to a project that is deployed by Cloudflare or Vercel. We at Val Town are unqiuely positioned to accomplish this because we host both your source code and your deployments.
How did we migrate 61 blog posts – with images, videos, and intricate formatting and styles – to an entirely new blog in a single day?
We didn't. We left them where they are, and proxy to them.
Writing a proxy in Val Town (or any functions platform with the 'fetch handler' interface) is always a delight:
const OLD_BLOG_HOST = "https://val-town-blog.pages.dev/";
export async function proxy(req: Request): Promise<Response> {
const url = new URL(req.url);
return fetch(OLD_BLOG_URL + url.pathname + url.search, {
method: req.method,
headers: req.headers,
});
}
So if you go to view blog.val.town/blog/val-town-newsletter-24 you'll see exactly what you would at val-town-blog.pages.dev/blog/val-town-newsletter-24. I find it somehow eerily that proxies work so well.
So far we've had reasonable success with this technique of migrating to Val Town quickly by proxying most old content, and only rebuilding the homepage and new posts. I first used this technique on my personal website, stevekrouse.com, and was pleased to see it continue to work here. If you, dear reader, have a blog you'd like to migrate to Val Town in this way and get stuck, shoot me an email at steve@val.town – I'd be happy to help.
Given this, I was able to vibecode my way through building the core blog with OpenTownie in about half a day, and then it took Jackson about half a day to make it pretty. Honestly, this blog post has taken more time to write than entire the blog migration itself.
If you are starting a new blog from scratch, Remix this markdown blog starter.
If you are migrating an existing blog, feel free to Remix this blog, because it comes with good patterns for proxying to old content and rendering new content.