SlideShare a Scribd company logo
Migra&ng 
17 
WP 
blogs 
on 
WIRED.com 
into 
one 
WordPress 
Install 
Kathleen 
Vignos 
@WordCampSF 
2014
Issue 
Kathleen 
Vignos 
WIRED: 
Magazine 
since 
1993 
@WordCampSF 
2014 @kathleencodes
Kathleen 
Vignos 
WIRED: 
Website 
since 
1994 
@WordCampSF 
2014 @kathleencodes
Cross 
Posts 
and 
Redirects 
Kathleen 
Vignos 
We 
Got 
99 
Problems... 
@WordCampSF 
2014 @kathleencodes 
Flat 
Files Old 
CMS 
20 
Years 
of 
Digital 
Content 
External 
Homepage 
Curator 
App 
Third-­‐Party 
Editorial 
Workflow 
App 
35+ 
Blogs
WordPress 
Problems: 
Separate 
Installs, 
Themes, 
Plugins 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
WordPress 
Problems: 
Upgrades 
and 
Deployments 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
WordPress 
Problems: 
35x2 
Separate 
Logins 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
WordPress 
Problems: 
Create 
User 
35x2 
Times 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
Kathleen 
Vignos 
API 
Problems: 
RSS 
Everywhere 
@WordCampSF 
2014 @kathleencodes
Selling 
Points 
• 
Precursor 
to 
full-­‐scale 
redesign 
• 
BeCer 
site 
performance 
• 
Faster 
future 
development 
! 
Project 
Scope 
• 
Migrate 
17 
acHve 
blogs 
only 
• 
NO 
DESIGN 
CHANGES 
• 
Homepage 
to 
PHP, 
schedule 
in 
WP 
• 
Manage 
edit 
workflow 
in 
WP 
Kathleen 
Vignos 
The 
Solu&on: 
Project 
Pangea 
@WordCampSF 
2014 @kathleencodes
1 2 3 4 5 
Kathleen 
Vignos 
WordPress 
Migra&on 
Steps 
@WordCampSF 
2014 @kathleencodes 
Purge 
Data 
Update 
Taxonomies 
Export, 
Import 
Sanity 
Checks 
Add 
Helpers
Kathleen 
Vignos 
Migra&on: 
Purge 
Data 
• 
Trash 
• 
Revisions 
• 
Comments, 
trackbacks, 
pingbacks 
• 
Links 
• 
Transients 
• 
Authors 
with 
no 
posts 
• 
Categories 
and 
tags 
with 
0, 
1, 
2 
posts 
@WordCampSF 
2014 @kathleencodes
Migra&on: 
Taxonomy 
Updates 
• 
Add 
blog 
category 
for 
each 
post 
• 
Convert 
categories 
to 
tags 
• 
ShiY 
remaining 
categories 
to 
subcategories 
• 
Use 
wp-­‐cli 
Kathleen 
Vignos 
http://wp-cli.org 
@WordCampSF 
2014 @kathleencodes
Migra&on: 
Export/Import 
with 
WordPress 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
Migra&on: 
Export/Import, 
Custom 
Scripts 
• 
Max 
import 
20MB 
(configurable) 
• 
Large 
export 
can 
trigger 
PHP 
memory 
limits 
Kathleen 
Vignos 
Why 
we 
needed 
custom 
scripts: 
! 
1. 
WP 
Export/Import 
Limits 
2. 
DuplicaHon 
of 
authors 
across 
blogs 
3. 
Mapping 
posts 
to 
new 
categories 
4. 
Storing 
old 
post 
ID 
in 
post 
meta 
@WordCampSF 
2014 @kathleencodes
Migra&on: 
Export/Import, 
Custom 
Scripts 
Our 
migraHon 
script 
process: 
! 
1. 
Nightly 
backup 
of 
producHon 
DB 
to 
S3 
2. 
gzip 
pulled 
down 
from 
S3 
to 
a 
local 
DB 
3. 
Scripts 
run 
against 
local 
DB 
4. 
DB 
saved 
back 
to 
S3 
5. 
Test, 
sanity 
checks 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
Kathleen 
Vignos 
Migra&on: 
Sanity 
Checks 
Can’t 
manually 
test 
100K+ 
posts, 
so… 
! 
• 
Script 
to 
check 
data 
mapping 
• 
Script 
to 
check 
data 
integrity 
@WordCampSF 
2014 @kathleencodes
Migra&on: 
Sanity 
Checks, 
Mapping 
Check 
data 
mapping 
from 
old 
site 
to 
new 
wp_gadgetlab_posts LEFT OUTER JOIN wp_posts 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes 
✓ 
All 
old 
posts 
in 
new 
table 
✓ 
Post 
content 
matches 
✓ 
Post 
aCachments 
map 
to 
parent 
post 
✓ 
Post 
terms 
carried 
over 
hCp://wrd.cm/pangea-­‐data-­‐mapping-­‐gist
Migra&on: 
Sanity 
Checks, 
Integrity 
Check 
that 
data 
on 
new 
site 
makes 
sense 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes 
✓No 
uncategorized 
(homeless) 
posts 
✓No 
phantom 
authors 
✓No 
duplicate 
posts 
✓No 
orphans: 
postmeta, 
aCachments, 
galleries 
hCp://wrd.cm/pangea-­‐data-­‐integrity-­‐gist
Migra&on: 
Helpers 
hCps://wordpress.org/plugins/restrict-­‐categories/ 
! 
• 
Set 
author 
default 
category 
(custom 
user 
meta) 
Kathleen 
Vignos 
• 
New 
custom 
roles 
and 
capabiliHes 
Ghost, 
Top 
Editor, 
Producer 
! 
• 
Restrict 
Categories 
plugin: 
@WordCampSF 
2014 @kathleencodes
Cross 
Posts 
and 
Redirects 
Kathleen 
Vignos 
The 
Results: 
Project 
Pangea 
@WordCampSF 
2014 @kathleencodes 
Flat 
Files Old 
CMS 
20 
Years 
of 
Digital 
Content 
External 
Homepage 
Curator 
App 
Third-­‐Party 
Editorial 
Workflow 
App 
1 
35+ 
WP 
Install 
Blogs
✓Easier plugin and widget management 
Kathleen 
Vignos 
The 
Results: 
Project 
Pangea 
@WordCampSF 
2014 @kathleencodes
Kathleen 
Vignos 
The 
Results: 
Project 
Pangea 
✓Easier user administration 
@WordCampSF 
2014 @kathleencodes
The 
Results: 
Project 
Pangea 
✓No more RSS needed for aggregating posts 
✓One single RESTful API 
Kathleen 
Vignos 
@WordCampSF 
2014 @kathleencodes
✓Automated deployments with Jenkins and git tags 
Kathleen 
Vignos 
The 
Results: 
Project 
Pangea 
@WordCampSF 
2014 @kathleencodes
The 
Results: 
Project 
Pangea 
of 
happiness 
and 
world 
peace 
Kathleen 
Vignos 
✓Achievement 
@WordCampSF 
2014 @kathleencodes
Kathleen 
Vignos 
Thank 
You! 
! 
Download 
slides: 
hCp://wrd.cm/wcsf2014-­‐kv 
is hiring! 
hCp://wrd.cm/jobs 
@WordCampSF 
2014 @kathleencodes

More Related Content

PPTX
OpenStack Documentation in the Open
PPTX
Collaborating on GitHub for Open Source Documentation
PDF
Contributing Back to WordPress - Getting Involved in the Community
PDF
Bootstrapping your plugin
PDF
Frontend as a first class citizen
PDF
Building plugins like a pro
PDF
Improving the WordPress Ecosystem with Tide
PDF
DocOps: Documentation at the Speed of Agile
OpenStack Documentation in the Open
Collaborating on GitHub for Open Source Documentation
Contributing Back to WordPress - Getting Involved in the Community
Bootstrapping your plugin
Frontend as a first class citizen
Building plugins like a pro
Improving the WordPress Ecosystem with Tide
DocOps: Documentation at the Speed of Agile

What's hot (20)

PDF
R Markdown, Rpubs & github publishing and Shiny by Example
PPTX
Version Control, Writers, and Workflows
PDF
Atlassian User Group NYC April 27 2017 ScriptRunner Workshop
PPTX
Getting Started with WordPress Plugin Development
PPTX
The dev ops code has no servers
PPTX
Salesforce winter 16 release
PDF
Convert your Full Trust Solutions to the SharePoint Framework (SPFx)
PPTX
Documentation-driven development for Python web APIs v2
PDF
Mongo db parse-v17
PPTX
AUGNYC June 21 Presentations
PDF
Salvatore Laisa - Da Angular a React - Un viaggio inaspettato
PPTX
Delivering successful API integrations with documentation-driven development
PPTX
PyBCN 2020
PDF
Tipping the scale - Eyal Eizenberg - Wix
PPTX
Is TDD dead or alive?
PDF
How to use Salesforce Workbench like a Pro
PPTX
Automated Testing – Web, Mobile, Desktop - Challenges and Successes
PPTX
Moving Beyond WordPress At Tech in Asia
PDF
Stencil the time for vanilla web components has arrived
PPTX
Documentation-driven development for Python web APIs
R Markdown, Rpubs & github publishing and Shiny by Example
Version Control, Writers, and Workflows
Atlassian User Group NYC April 27 2017 ScriptRunner Workshop
Getting Started with WordPress Plugin Development
The dev ops code has no servers
Salesforce winter 16 release
Convert your Full Trust Solutions to the SharePoint Framework (SPFx)
Documentation-driven development for Python web APIs v2
Mongo db parse-v17
AUGNYC June 21 Presentations
Salvatore Laisa - Da Angular a React - Un viaggio inaspettato
Delivering successful API integrations with documentation-driven development
PyBCN 2020
Tipping the scale - Eyal Eizenberg - Wix
Is TDD dead or alive?
How to use Salesforce Workbench like a Pro
Automated Testing – Web, Mobile, Desktop - Challenges and Successes
Moving Beyond WordPress At Tech in Asia
Stencil the time for vanilla web components has arrived
Documentation-driven development for Python web APIs
Ad

Similar to WordCamp SF 2014 - WIRED Migration Project (20)

PDF
Building the next generation of themes with WP Rig 2.0
PDF
Implementing Google Analytics in WordPress
PDF
Things you should know about WordPress (but were always too afraid to ask): W...
PPTX
Best Practices and Tips on Migrating a Legacy-Based CMS to Drupal
PDF
Gutenberg and Headless WordPress.pdf
PDF
WordCamp Greenville 2018 - Beware the Dark Side, or an Intro to Development
PPTX
PDF
Word camp 2013 migration
PDF
Wordpress beyond blogging
PDF
Migration Best Practices - Search Y 2019, Paris
PDF
Get Involved with WordPress
PPTX
The WordPress University
PPTX
Developing Complex WordPress Sites without Fear of Failure (with MVC)
PDF
WordPress Beginners Workshop
PDF
Plugin development demystified 2017
KEY
Custom Post Types in Depth at WordCamp Montreal
PPT
WordPress Complete Tutorial
PDF
Plesk WP Toolkit - Growing Together @Cloudfest 2022
PPTX
Csun retrofitting anoosha&sathish-2
PDF
Upgrading to Drupal 8: Benefits and Gotchas
Building the next generation of themes with WP Rig 2.0
Implementing Google Analytics in WordPress
Things you should know about WordPress (but were always too afraid to ask): W...
Best Practices and Tips on Migrating a Legacy-Based CMS to Drupal
Gutenberg and Headless WordPress.pdf
WordCamp Greenville 2018 - Beware the Dark Side, or an Intro to Development
Word camp 2013 migration
Wordpress beyond blogging
Migration Best Practices - Search Y 2019, Paris
Get Involved with WordPress
The WordPress University
Developing Complex WordPress Sites without Fear of Failure (with MVC)
WordPress Beginners Workshop
Plugin development demystified 2017
Custom Post Types in Depth at WordCamp Montreal
WordPress Complete Tutorial
Plesk WP Toolkit - Growing Together @Cloudfest 2022
Csun retrofitting anoosha&sathish-2
Upgrading to Drupal 8: Benefits and Gotchas
Ad

More from kvignos (6)

PDF
LeadingEng Growing the Next Generation of Leaders, Kathleen Vignos.pdf
PDF
Keeping up your technical skills as a manager
PDF
How to keep up your technical skills without annoying your team(s)
PDF
5 leadership skills every engineer needs - North Bay Python
PDF
Managing engineering teams through constant change final
PDF
WIRED and the WP REST API
LeadingEng Growing the Next Generation of Leaders, Kathleen Vignos.pdf
Keeping up your technical skills as a manager
How to keep up your technical skills without annoying your team(s)
5 leadership skills every engineer needs - North Bay Python
Managing engineering teams through constant change final
WIRED and the WP REST API

Recently uploaded (20)

PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PDF
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Accuracy of neural networks in brain wave diagnosis of schizophrenia
PPTX
1. Introduction to Computer Programming.pptx
PPTX
Group 1 Presentation -Planning and Decision Making .pptx
PDF
A comparative analysis of optical character recognition models for extracting...
PDF
Machine learning based COVID-19 study performance prediction
PPT
Teaching material agriculture food technology
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PPTX
SOPHOS-XG Firewall Administrator PPT.pptx
PPTX
A Presentation on Artificial Intelligence
PDF
MIND Revenue Release Quarter 2 2025 Press Release
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Empathic Computing: Creating Shared Understanding
PDF
Mushroom cultivation and it's methods.pdf
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
Diabetes mellitus diagnosis method based random forest with bat algorithm
Accuracy of neural networks in brain wave diagnosis of schizophrenia
1. Introduction to Computer Programming.pptx
Group 1 Presentation -Planning and Decision Making .pptx
A comparative analysis of optical character recognition models for extracting...
Machine learning based COVID-19 study performance prediction
Teaching material agriculture food technology
Network Security Unit 5.pdf for BCA BBA.
Advanced methodologies resolving dimensionality complications for autism neur...
Assigned Numbers - 2025 - Bluetooth® Document
SOPHOS-XG Firewall Administrator PPT.pptx
A Presentation on Artificial Intelligence
MIND Revenue Release Quarter 2 2025 Press Release
Building Integrated photovoltaic BIPV_UPV.pdf
Unlocking AI with Model Context Protocol (MCP)
Per capita expenditure prediction using model stacking based on satellite ima...
Empathic Computing: Creating Shared Understanding
Mushroom cultivation and it's methods.pdf

WordCamp SF 2014 - WIRED Migration Project

  • 1. Migra&ng 17 WP blogs on WIRED.com into one WordPress Install Kathleen Vignos @WordCampSF 2014
  • 2. Issue Kathleen Vignos WIRED: Magazine since 1993 @WordCampSF 2014 @kathleencodes
  • 3. Kathleen Vignos WIRED: Website since 1994 @WordCampSF 2014 @kathleencodes
  • 4. Cross Posts and Redirects Kathleen Vignos We Got 99 Problems... @WordCampSF 2014 @kathleencodes Flat Files Old CMS 20 Years of Digital Content External Homepage Curator App Third-­‐Party Editorial Workflow App 35+ Blogs
  • 5. WordPress Problems: Separate Installs, Themes, Plugins Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 6. WordPress Problems: Upgrades and Deployments Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 7. WordPress Problems: 35x2 Separate Logins Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 8. WordPress Problems: Create User 35x2 Times Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 9. Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 10. Kathleen Vignos API Problems: RSS Everywhere @WordCampSF 2014 @kathleencodes
  • 11. Selling Points • Precursor to full-­‐scale redesign • BeCer site performance • Faster future development ! Project Scope • Migrate 17 acHve blogs only • NO DESIGN CHANGES • Homepage to PHP, schedule in WP • Manage edit workflow in WP Kathleen Vignos The Solu&on: Project Pangea @WordCampSF 2014 @kathleencodes
  • 12. 1 2 3 4 5 Kathleen Vignos WordPress Migra&on Steps @WordCampSF 2014 @kathleencodes Purge Data Update Taxonomies Export, Import Sanity Checks Add Helpers
  • 13. Kathleen Vignos Migra&on: Purge Data • Trash • Revisions • Comments, trackbacks, pingbacks • Links • Transients • Authors with no posts • Categories and tags with 0, 1, 2 posts @WordCampSF 2014 @kathleencodes
  • 14. Migra&on: Taxonomy Updates • Add blog category for each post • Convert categories to tags • ShiY remaining categories to subcategories • Use wp-­‐cli Kathleen Vignos http://wp-cli.org @WordCampSF 2014 @kathleencodes
  • 15. Migra&on: Export/Import with WordPress Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 16. Migra&on: Export/Import, Custom Scripts • Max import 20MB (configurable) • Large export can trigger PHP memory limits Kathleen Vignos Why we needed custom scripts: ! 1. WP Export/Import Limits 2. DuplicaHon of authors across blogs 3. Mapping posts to new categories 4. Storing old post ID in post meta @WordCampSF 2014 @kathleencodes
  • 17. Migra&on: Export/Import, Custom Scripts Our migraHon script process: ! 1. Nightly backup of producHon DB to S3 2. gzip pulled down from S3 to a local DB 3. Scripts run against local DB 4. DB saved back to S3 5. Test, sanity checks Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 18. Kathleen Vignos Migra&on: Sanity Checks Can’t manually test 100K+ posts, so… ! • Script to check data mapping • Script to check data integrity @WordCampSF 2014 @kathleencodes
  • 19. Migra&on: Sanity Checks, Mapping Check data mapping from old site to new wp_gadgetlab_posts LEFT OUTER JOIN wp_posts Kathleen Vignos @WordCampSF 2014 @kathleencodes ✓ All old posts in new table ✓ Post content matches ✓ Post aCachments map to parent post ✓ Post terms carried over hCp://wrd.cm/pangea-­‐data-­‐mapping-­‐gist
  • 20. Migra&on: Sanity Checks, Integrity Check that data on new site makes sense Kathleen Vignos @WordCampSF 2014 @kathleencodes ✓No uncategorized (homeless) posts ✓No phantom authors ✓No duplicate posts ✓No orphans: postmeta, aCachments, galleries hCp://wrd.cm/pangea-­‐data-­‐integrity-­‐gist
  • 21. Migra&on: Helpers hCps://wordpress.org/plugins/restrict-­‐categories/ ! • Set author default category (custom user meta) Kathleen Vignos • New custom roles and capabiliHes Ghost, Top Editor, Producer ! • Restrict Categories plugin: @WordCampSF 2014 @kathleencodes
  • 22. Cross Posts and Redirects Kathleen Vignos The Results: Project Pangea @WordCampSF 2014 @kathleencodes Flat Files Old CMS 20 Years of Digital Content External Homepage Curator App Third-­‐Party Editorial Workflow App 1 35+ WP Install Blogs
  • 23. ✓Easier plugin and widget management Kathleen Vignos The Results: Project Pangea @WordCampSF 2014 @kathleencodes
  • 24. Kathleen Vignos The Results: Project Pangea ✓Easier user administration @WordCampSF 2014 @kathleencodes
  • 25. The Results: Project Pangea ✓No more RSS needed for aggregating posts ✓One single RESTful API Kathleen Vignos @WordCampSF 2014 @kathleencodes
  • 26. ✓Automated deployments with Jenkins and git tags Kathleen Vignos The Results: Project Pangea @WordCampSF 2014 @kathleencodes
  • 27. The Results: Project Pangea of happiness and world peace Kathleen Vignos ✓Achievement @WordCampSF 2014 @kathleencodes
  • 28. Kathleen Vignos Thank You! ! Download slides: hCp://wrd.cm/wcsf2014-­‐kv is hiring! hCp://wrd.cm/jobs @WordCampSF 2014 @kathleencodes