Cloning a site to a new URL on a different server

8 min read

Table of Contents

Introduction

In your workflow there may be times when you want to clone a duplicate of a site to a new URL, for example:

  • If your workflow entails using a development URL during development before transferring to a final production URL when a project is finished.
  • You might have a site as a blueprint site that you use as a foundation to work from, including a set of preinstalled themes and plugins with your most common option configurations.

You can use the GridPane single site migration/cloning tool located in the site backups to do this. This tool can be used for cloning a duplicate site to the same server or to another destination server.

This article is for cloning a duplicate site to a different server, if you want to clone a duplicate to the same server, please read this article.

Multisite Cloning and Improvements

Same-domain multisite cloning is now fully operational. We've also made improvements to our cloning scripts, and replaced WP-CLI Search Replace with Interconnectit Search Replace, and MySQLDump and import with MyDumper/MyLoader.
Multisite staging/cloning to a new domain is coming soon!
*Developer plan and above only

What Settings Clone Across

Cloning a duplicate site with a new URL to a different server will replicate a near identical state for the new site. The duplicate site will belong to the same owner if that user exists on the server, and it will match all the main control panel settings, including:

  • WordPress Core
  • WordPress Database structure
  • SSL
  • System User (this will be created if it doesn’t already exist)
  • PHP version and settings
  • All General customizer settings, including caching
  • All Security customizer settings
  • SMTP
  • Routing (www or none/root)
  • HTTP Authentication

We will also duplicate your site-specific PHP in settings and PHP process manager settings that GP-CLI manages, alongside the GP-CLI adjusted site-specific Nginx settings and any includes in your site-level Nginx or OpenLiteSpeed (OLS) directory.

One setting that does not transfer over when cloning is: AutoSSL. This setting is generally only relevant for multisite networks where you want to provision SSL certificates for new Alias domains automatically.

Cloning to Ubuntu 22.04 Servers

The default system user settings will be applied when you clone websites to Ubuntu 22.04 servers from 18.04 and/or 20.04 servers. This means the system user will have both SFTP and SSH access enabled. 

Getting Started

In this article, we will be using an example development site development.laser-cats.monster on an origin server called origin, to illustrate the steps to migrate this site to a new url of laser-cats.monster on a destination server named destination (original I know).

Screenshot_2020-01-26_at_20.07.02.png

Step 1. Preparation

Before you begin, there may be a few preparation steps you need to take. We also highly recommend that you review the information in this article:

Checks When Migrating/Cloning From One Server to Another

Important: Deactivate WP_DEBUG First

If you've had WP_DEBUG active, be sure to deactivate it before you proceed as it may cause a fatal error on the destination site.

SERVER-WIDE CONFIGS OR CUSTOM WORK

If you’ve set up any server-level configs, such as an Nginx config for using WP Rocket for Nginx or enabling webp, then you’ll also need to make sure these are set up once again on the new server. 

Unlike site-specific configurations, these will not be cloned across when moving sites from one server to another.

If you’ve added anything custom, such as installing additional software or server-level cronjobs, then you will also need to manually move/install/recreate these on your new server if they are still needed.

Disk Space

For your clone to begin, our systems require that your destination server has at least 110% of the origin site in free disk space. Please ensure you have ample free disk space before you proceed.

SSL Preparation (if applicable)

An SSL attempt will be made for the newly cloned site IF SSL is enabled on the original site. For this reason, it is important to make sure that your DNS is resolving correctly for the newly cloned site before you attempt cloning. This will speed up the search and replace because the system will just run a single compound regex. 

If DNS is not resolving, the clone will proceed as normal, but the SSL attempt will fail, and GridPane will ensure that all URLs in the database for the new site are replaced with HTTP variants, and this requires 3 passes instead of 1. You can then manually enable SSL later.

You can learn more about GridPane search and replace functions here:

GridPane Database Rewrites and Workflow

Step 2. Open the Website Customizer

Click on the Sites link in the GridPane main menu to go to the Sites management page.

Click on the URL of the site you want to clone a duplicate of in the active site’s panel.

This will open the site customizer.

Step 3. Configure Your URL and Destination Server

Click through to the Clone tab in the site customizer. Here you will find the Migrate/Clone tools.

Here we’ll make use of the second option.

Enter the new URL you’d like to clone your website to, and then select the new server from the dropdown list.

Please remember do not enter the URL with the www host included.

Step 3.1 Clone Information and Staging Site

Click the Migrate/Clone button to open the additional options modal:

At the top you’ll see the URL and destination server information, as well as a checkbox for whether to include the staging site. Here, a staging site doesn’t exist so the option is greyed out. However, if you do have a staging site you can clone this as well – check the box if you’d like to do so. 

Step 3.2 Database Rewrite Options

Below the information you’ll be presented with tabs to configure your new website, the first being whether to “Include Database Rewrites“.

Generally, you’re going to want to run database rewrites. This will run a search and replace and ensure that all of your URLs are set correctly. Two options are available to you:

  1. InterconnectIT
  2. WP-CLI

InterconnectIT is usually the best option as it’s more comprehensive. WP-CLI might be a little quicker, but it also has a higher chance of missing some rewrites.

Step 3.3 Set Your System User

In the next tab you can choose whether to use the same system user or create a new one. All the regular options are available:

We always recommend that every site have their own individual system user.

Step 3.4 Set SMTP

If you would like to set your SMTP API key you can choose this here:

Step 3.5 DNS Settings

If you would like to configure a DNS API provider for the site you can choose from your available keys:

Step 3.6 Set Your Local Backups

You can configure your local backups on the new site to match the current site settings, leave them turned off, or set an entirely custom schedule:

If setting different settings you have full granular controls just like in the backups tab:

Step 3.7 Set Your Remote Backups and Start Your Clone/Migration

Like local backups, you can choose to match the sites current settings, leave remote backups turned off, or set a new custom schedule:

Full configuration options are available for one chosen provider:

Once set you’re now ready to begin your migration.

Step 3.8 Clone Your Website

Once configured, click the Migrate / Clone Now button.

Your server will begin to clone the duplicate clone site to the destination server immediately.

Please be patient while the duplicate cloning process is ongoing, and refrain from making any changes to your site and either the origin server or the destination server.

You will receive a string of notifications to keep you informed about how the migration/clone is proceeding throughout the process. Please pay attention to these.

When the process is complete, your new site will appear in the active sites list.

Your settings on your newly cloned website will match up with your origin site.

Information

While most site clones are relatively quick, please note that large sites may take some time to complete.

Step 4. Check Your Cloned Website

You should check your duplicate site to make sure everything is as expected. The content and database will have been cloned across, and the URLs and file paths will have been updated to the new URL.

We will have matched most states for the GridPane features, including all PHP ini settings, PHP process manager settings, and Nginx configuration settings that have been adjusted by GP-CLI. We will also have migrated across cloned files from your Nginx includes directory.

Please ensure that everything has cloned correctly before deleting your previous site, and consider keeping the original for 1-2 weeks while backups on the new server have time to take place.

Screenshot_2020-01-26_at_20.10.34.png

Note

Should a site clone fail to complete for any reason, it will leave a copy of the gzip file in place that looks like GPBUP-2.website.com-CLONE.gz. We have had one report of this being left behind after a successful clone. This is very uncommon, but should you find the process has not deleted this gzip file after successfully cloning your website, you can delete this manually.

Cloning Staging Websites

As noted in Step 3.1, you can choose to clone your staging site along with the main site if you would like to do so.

You can also clone individual staging sites to a different URL either on the same server or a new server if you have a need to do so though. You will find the same options for cloning in your staging site’s customizer, and you can follow the same steps above like you would when cloning a production website.

One thing you can’t do, however, is create or clone staging sites to “staging” subdomains on GridPane. For example, if you try to create the website “staging.website.com” as a regular site, it will fail and result in an error message. This will also fail in the exact same way during the cloning process.