KeystoneJS logo
Ghost logo

From KeystoneJS to Ghost

We are the KeystoneJS to Ghost migration experts

Last verified:



Challenges with KeystoneJS

Key pain points

The biggest challenge with KeystoneJS is that it hands you all the responsibility that a managed CMS would normally handle. Deployment is entirely on you, and the documentation around production hosting, Docker configuration, and scaling is thin. We've seen teams struggle to go from a smooth local development experience to a reliable production setup, especially if they don't have dedicated DevOps support. The admin UI Docker image alone can balloon to over a gigabyte, which is a headache for containerised deployments.

The community around Keystone is significantly smaller than competitors like Strapi or Payload. That means fewer tutorials, fewer plugins, and slower answers when you hit an edge case. The ecosystem of ready-made integrations is almost non-existent, so you'll be building most things from scratch. For an agency working on client projects with deadlines, that time cost adds up quickly.

Content editors also tend to have a harder time with Keystone compared to more polished alternatives. The admin UI is functional but feels utilitarian, and non-technical users often need more onboarding than you'd expect. There's no visual editing, no preview infrastructure, and no real content workflow features like drafts, publishing schedules, or approval chains without building them yourself. If your client's content team needs a CMS they can pick up and run with, Keystone usually isn't the answer.

Help me migrate


Deployment complexity in KeystoneJS

Deployment complexity

Self-hosting is the only option, and the docs don't hold your hand. Getting Keystone into production requires real infrastructure knowledge, and the large Docker image sizes make it worse.

Small community in KeystoneJS

Small community and ecosystem

Compared to Strapi or even Payload, the community is much smaller. Fewer plugins, fewer tutorials, and slower support when things go wrong.

No built-in content workflows in KeystoneJS

No built-in content workflows

There are no turnkey drafts, scheduled publishing, or approval chains. Keystone provides field primitives that can be assembled into publishing workflows, but you need to wire them up yourself.

Dated admin UI in KeystoneJS

Admin UI feels dated

The admin panel is functional but lacks the polish and UX of modern CMS interfaces. Non-technical editors often find it confusing and need more training.

No visual editing in KeystoneJS

No visual editing or live preview

There's no way for editors to see content in context before publishing. You'd need to build your own preview infrastructure, which is a significant engineering effort.

Scaling challenges in KeystoneJS

Scaling requires significant effort

Running Keystone under high traffic means managing session stores, reverse proxies, and server resources yourself. It doesn't scale as smoothly as cloud-native CMS alternatives.



Benefits of Ghost

Key advantages

Ghost is genuinely great if all you want is a fast, clean, no-nonsense blogging machine. It keeps things beautifully simple: a slick Markdown editor, zero clutter, and performance scores so good they’ll make WordPress users cry into their PHP logs. If your plan is “just publish content,” Ghost actually gets out of your way and lets you do that.

The built-in memberships and payments system is also a win. You can slap a paywall on your content, charge people to read your mediocre hot takes, and do it all without duct-taping together 12 plugins. For solo creators, small publications, and anyone who wants a simple writing-first experience, Ghost delivers exactly what it promises and nothing you didn’t ask for.

Start my migration


Lightweight JSON API

Lightweight JSON API

Ghost’s API is fast, predictable, and doesn’t make you fight a schema just to fetch a title. It’s perfect for JAMStack setups where you want speed without ceremony. Pull content, ship pages, move on with your life.

Intuitive Markdown editor

Intuitive Markdown editor

If you enjoy writing without 19 toolbars screaming at you, Ghost’s Markdown editor is bliss. Clean, distraction-free, and actually enjoyable to use.

Built-in membership system

Built-in membership system

Memberships, paywalls, and subscriptions come built in, no plugin Frankenstein required. Hook up Stripe and you’re basically running your own mini-Substack in minutes.

SEO-friendly defaults

SEO-friendly defaults

Ghost ships with fast performance, clean URLs, structured data, and proper metadata, without needing an SEO plugin the size of a small country. Most sites hit solid scores straight out of the box.

Native subscription support

Native subscription support

You don’t need 3 SaaS tools duct-taped together to run a newsletter. Ghost handles email delivery, subscriber lists, and automated posts natively.

Easy theme customization

Easy theme customization

Themes are simple to tweak thanks to Ghost’s handlebars-based templates. If you know basic HTML/CSS, you can make it look exactly how you want without fighting a visual builder from 2011.





Common questions

KeystoneJS to Ghost migration FAQs

Answers to the most common questions about KeystoneJS to Ghost migration

What makes migrating from KeystoneJS difficult?
KeystoneJS stores data through Prisma, so the database layer is well-structured and easy to export. The harder part is replacing everything Keystone doesn't give you. Most Keystone projects have custom-built preview systems, publishing workflows, and access control logic that are tightly coupled to the Node.js backend. Rebuilding those features in a new CMS takes planning. We typically budget 4 to 8 weeks for a Keystone migration depending on how much custom infrastructure the team has built around it.
Why do teams move away from KeystoneJS?
Deployment complexity is the number one reason. Teams love Keystone during local development, then hit a wall getting it reliably into production. The Docker images can balloon past a gigabyte, the docs don't cover production hosting well, and there's no managed hosting option. The small community compounds this problem. When you hit an edge case, there are fewer people who've solved it before. Content editors also struggle with the admin UI, which lacks visual editing, live preview, and built-in publishing workflows that competing platforms ship by default.
How do we extract our content from KeystoneJS?
Since Keystone uses Prisma ORM, your content lives in standard PostgreSQL, MySQL, or SQLite tables with clean schemas. You can export directly from the database using SQL dumps or Prisma's query API. The content model is defined in your TypeScript codebase, so mapping fields to a new CMS is straightforward. We write automated scripts that handle the data transformation, including resolving relationships between lists and migrating file references. For a project with 20 to 50 Keystone lists, extraction and transformation usually takes 1 to 2 weeks.
How much does Ghost CMS really cost beyond the "free" open source version?
Ghost is free to self-host, but "free" is misleading. You'll need a VPS ($5-$20/month minimum), someone to handle server maintenance, security updates, SSL certificates, and backups. That's either your time or a developer's hourly rate. Realistically, self-hosted Ghost costs $50-$200/month in labour and infrastructure for a small team. Ghost's managed hosting (Ghost Pro) starts at $9/month for the Starter plan (500 members), jumps to $25/month for Creator (1,000 members), and scales to $199/month for the Business tier. Once your membership list grows past a few thousand, costs climb fast. We've seen publishers hit $300+/month on Ghost Pro before questioning whether the platform still made sense for them.
Does Ghost need a developer to maintain it?
If you're self-hosting, yes. Ghost runs on Node.js and requires regular updates, database maintenance (MySQL), and server monitoring. Major version upgrades (Ghost 4 to 5, for example) can break themes and integrations, and someone technical needs to handle those. On Ghost Pro, maintenance is handled for you, but customisation still requires a developer. Custom themes use Handlebars templating, and anything beyond basic styling means editing theme files and redeploying. If your team is purely non-technical and you want to go beyond Ghost's default themes, you'll need developer support on an ongoing basis.
When should you migrate away from Ghost?
Ghost hits its ceiling when you need more than blog posts and newsletters. If you're trying to build landing pages, manage structured content across multiple page types, run an ecommerce store, or handle multi-language content, Ghost wasn't designed for any of that. We've migrated publishers off Ghost when they outgrew the "blog plus newsletter" model and needed a real content platform. The migration itself is painless. Ghost's JSON API makes content extraction simple, and posts map cleanly to markdown. The typical timeline is 4-6 weeks to move content into a headless CMS and rebuild the frontend.
Can Ghost handle a site with more than just a blog?
Barely. Ghost gives you two content types, posts and pages, and that's it. There's no custom content modelling, no relational fields, no structured data beyond tags and authors. You can hack together something with custom routes and internal tags, but it's brittle and hard to maintain. If you need case studies, service pages, team directories, or any structured content beyond articles, you're fighting the platform. Ghost is excellent at what it does. It just doesn't do very much. For sites that need a blog alongside other content types, a headless CMS gives you the flexibility Ghost intentionally leaves out.


Get in touch

Fill out the form below and we'll get back to you