When migrating from WordPress CMS to another CMS there are a couple of ways to easily export all your posts and media files:
- GraphQL API for WordPress
- Convert WordPress to Markdown
In this guide we will be using the WPGraphQL plugin and Netlify to deploy a Gatsby website.
Step 1. Fork the gatsbyjs/gatsby-starter-wordpress-blog repo on Github
data:image/s3,"s3://crabby-images/a393f/a393ff6a7be722431d6ffc8b4aab6f6310c60b11" alt="WordPress to Gatsby on netlify ☄️ image 32 1024x695 - WordPress to Gatsby on netlify ☄️"
Step 2. Edit the gatsby-config.js
file and under gatsby-source-wordpress
change the url
option so that it points to your WordPress instance GraphQL url. E.g. https://yoursite.com/graphql
data:image/s3,"s3://crabby-images/9f663/9f6636e0dc72ba646f6695827d126a79bdf764cb" alt="WordPress to Gatsby on netlify ☄️ image 30 - WordPress to Gatsby on netlify ☄️"
Step 3. Install WordPress plugins
Install and activate both of the following plugins in a live WordPress instance.
data:image/s3,"s3://crabby-images/d0044/d0044f6a0cb12b00327167415a14228c338041c5" alt="WordPress to Gatsby on netlify ☄️ image 31 - WordPress to Gatsby on netlify ☄️"
Step 4. Create a netlify account, connect Github account and deploy from the newly created repo
data:image/s3,"s3://crabby-images/7520e/7520e20e62cf3120d3a14771e207d690ddd52759" alt="WordPress to Gatsby on netlify ☄️ image 36 1024x655 - WordPress to Gatsby on netlify ☄️"
data:image/s3,"s3://crabby-images/1db55/1db55efb21888a7458fe2d4130867f41df4f242f" alt="WordPress to Gatsby on netlify ☄️ image 37 1024x874 - WordPress to Gatsby on netlify ☄️"
That’s it, go ahead and check your new Gatsby website on netlify.
data:image/s3,"s3://crabby-images/10100/10100c6a75b912de3316d4a3bc572aadd9b22dde" alt="WordPress to Gatsby on netlify ☄️ image 35 - WordPress to Gatsby on netlify ☄️"
Troubleshooting common problems:
make sure your image names are not too long:
data:image/s3,"s3://crabby-images/cbe8a/cbe8a4b365fe0358c852d7e24fd2f2303961b6db" alt="WordPress to Gatsby on netlify ☄️ image 34 1024x523 - WordPress to Gatsby on netlify ☄️"
and .htaccess is not limiting access
data:image/s3,"s3://crabby-images/2f642/2f6422ce3382b1ecc16fe2b5ecdd013c6d158854" alt="WordPress to Gatsby on netlify ☄️ image 33 - WordPress to Gatsby on netlify ☄️"