How to Migrate a cPanel Server to Linode

Traducciones al Español
Estamos traduciendo nuestros guías y tutoriales al Español. Es posible que usted esté viendo una traducción generada automáticamente. Estamos trabajando con traductores profesionales para verificar las traducciones de nuestro sitio web. Este proyecto es un trabajo en curso.
Create a Linode account to try this guide with a $ credit.
This credit will be applied to any valid services used during your first  days.

This guide describes how to migrate from a server running WHM and cPanel on another hosting service to Linode. This transfer is completed using cPanel’s official Transfer Tool. Prior to using the Transfer Tool, you will complete a basic WHM installation on a new Linode. Read the Best Practices when Migrating to Linode guide for more information about migrating your sites before beginning.

Note

The Transfer Tool only transfers your cPanel accounts, and not your WHM settings. You will need to recreate your WHM settings on your new Linode separately.

This guide does not cover how to handle cPanel deployments that are part of a DNS cluster. For guidance on migrating a cPanel server in a DNS cluster, see cPanel’s official documentation.

Migrate Your cPanel Accounts

Deploy cPanel on Linode

The first step is to deploy cPanel on the Linode platform. cPanel can be installed and configured on a Linode Compute Instance using one of the following methods:

  • Linode Marketplace: Deploy the cPanel App through the Linode Marketplace to automatically install cPanel/WHM. This is the easiest method and enables you to quickly get up and running without needing to install cPanel manually. Review the Deploy cPanel through the Linode Marketplace guide for more details.

  • Manual Installation: For more control over every step of the installation process, cPanel can be manually installed on a new Compute Instance. If choosing this method, review Install cPanel on CentOS or reference cPanel’s official Installation Guide.

Whichever method you choose, select a Linode Compute Instance plan with enough storage capacity to accommodate the data within the cPanel accounts on your current host.

Warning
When performing the initial cPanel configuration steps, use the Linode’s generic domain name for WHM’s Hostname setting. This generic domain will be listed under the Reverse DNS column of the Networking tab for your instance in the Cloud Manager and it will have the form 203-0-113-0.ip.linodeusercontent.com. Review the Viewing IP Addresses guide for more details. If you set the Hostname as your domain name now, the WHM and cPanel dashboards on your new Linode will redirect to your current host and you will not be able to access the settings for your new Linode.

Use the cPanel Transfer Tool

Once cPanel has been installed, use the built-in Transfer Tool to copy your data from your existing server to your new Linode instance.

  1. Visit http://your_linode_ip_address:2087 in your web browser to load the WHM dashboard. Bypass the browser warning message about the web server’s SSL/TLS certificate.

  2. Log in to WHM with the root user and password for your Linode.

  3. In the menu on the left side of the WHM dashboard, scroll down to the Transfers section and choose the Transfer Tool option:

  4. In the Remote Server Address field, enter your current host’s IP address:

  5. Enter the root credentials for your current host under the Authentication section. You will need the root password for your current host and root logins should be allowed on that host.

    If you don’t have root credentials or if root logins are not allowed, you will need the credentials of another user with sudo privileges on your current host. Enter that username and password and choose sudo for the Root Escalation Method field.

  6. Click the Fetch Account List button at the bottom of the form.

  7. A new page will load with forms listing the Service Configurations, Packages, and Accounts from your current host. Click the corresponding checkbox for each item in these sections to enable their transfer. Click the Show button for the Service Configurations section to see the options in that area:

  8. When all of the options are selected, click the Copy button at the bottom of the page. A new page will appear showing the progress of your transfer:

Verify Transferred Accounts

You should verify that all information from your cPanel accounts was transferred successfully to your Linode. To do this, you will log in to cPanel on your new Linode for each account that was transferred and review the contents of the dashboard. The specific information in the following sections should also be reviewed for each account.

Verify IP Address Assignments

The Transfer Tool will attempt to assign your new Linode IP to the transferred cPanel accounts. It will sometimes fail and leave your old host’s IP in place, so you should confirm which IP is assigned to your cPanel accounts:

  1. In the menu on the left side of the WHM dashboard, navigate to the Account Information section and choose the List Accounts option:

  2. Verify that your new Linode’s IP is listed for the accounts. If it is not listed, use the cPanel IP Migration Wizard tool to update your account configurations with the new IP.

Verify SSL Certificates

The official cPanel migration documentation notes that SSL certificates (apart from the self-signed certificates that cPanel provides) need to be manually downloaded from the source cPanel server and then installed on the new Linode.

When writing this guide it was found that the SSL certificates from the test source server were transferred automatically. It’s recommended that you verify that your SSL certificates are present on the new server, and that you backup the certificate files from the source server.

  1. The SSL certificates on your current cPanel host are located in /etc/ssl. Download them to your computer:

    scp -r root@current_host_ip_address:/etc/ssl ~
    

    You can also use FileZilla to download the files.

    If you are not able to login as root to your host, login as a user with sudo privileges and then copy those files to the user’s home folder:

    ssh your_sudo_user@current_host_ip_address
    sudo cp -r /etc/ssl ~
    sudo chown $(whoami):$(whoami) ssl
    exit
    

    Then download the files from the user’s home folder to your computer:

    scp -r root@current_host_ip_address:~/ssl ~
    

    After downloading the files, log back into your host and remove the files from the sudo user’s home folder:

    rm -r ~/ssl
    
  2. If you do not have terminal access to your current host, you can also copy the certificates from the cPanel interface. Load cPanel on your current host by visiting http://your_current_host_ip_address:2083 in your web browser and enter your cPanel account credentials.

    Visit the SSL/TLS section and view the private keys, certificate signing requests, and certificates listed. Copy and paste each of these to text files on your computer. Repeat this for each cPanel account on your current host.

  3. Visit http://your_linode_ip_address:2083 in your web browser to load the cPanel dashboard on your Linode. Bypass the browser warning message about the web server’s SSL/TLS certificate.

  4. When presented with the cPanel Login form, enter the credentials you use for your cPanel account on your current host. These credentials were transferred by the Transfer Tool and are the same as before.

  5. Visit the SSL/TLS section and review the private keys and certificates sections. If you do not see your private keys and certificates, use the Upload a New Private Key and Upload a New Certificate forms to add them.

  6. Visit the SSL/TLS section again and navigate to the Install and Manage SSL for your site (HTTPS) page. Click the Certificate Details link to view which certificate is installed for your site.

  7. If your certificate is not being used, click the Browse Certificates button and choose your certificate from the dialog that appears. After choosing your certificate, click the Install Certificate button at the bottom of the page.

  8. Repeat steps 4-8 for each transferred cPanel account.

Test Your New cPanel Deployment

If you visit your Linode’s IP address in your browser, the website served by your cPanel account will not appear. This is because the cPanel server expects your domain name to be passed in your web request, and you have not updated your DNS yet.

The Previewing Websites Without DNS guide describes a way to visit your domain prior to updating your DNS records. When you have updated your DNS, this workaround will no longer be necessary to view your site.

Migrating DNS Records

After completing the cPanel migration, update your DNS records to reflect your new Linode’s IP. Once this is done, site visitors will start loading your cPanel accounts’ services from your new Linode.

(Optional) Prepare Your Domain Name to Move

A recommended first step is to lower the Time to Live (TTL) setting for your domain so that the migration won’t have a negative impact on your site’s visitors. TTL tells DNS caching servers how long to save information about your domain. Because DNS addresses don’t often change server IP addresses, default TTL is typically about 24 hours.

When changing servers, however, make the TTL shorter to make sure that when you update your domain information, it takes effect quickly. Otherwise, your domain could resolve to your old server’s IP address for up to 24 hours.

  1. Locate your current nameservers. If you’re not sure what your nameservers are, use a Whois Search tool. You will see several nameservers listed, probably all at the same company.

    You can usually derive the website of your nameserver authority (the organization that manages your DNS) from the nameservers you find in the Whois report (e.g. ns1.linode.com corresponds with linode.com). Sometimes the labeling for the nameservers is not directly related to the organization’s website, and in those cases you can often find the website by plugging the nameserver into a Google search.

  2. Contact your nameserver authority for details on how to shorten the TTL for your domain. Every provider is a little different, so you may have to ask for instructions.

    Most nameserver authorities will allow you to set the TTL on your domain or on individual records, but some do not allow this setting to be edited. Here are support documents from some common authorities that mention how they manage TTL:

  3. Make a note of your current TTL. It will be listed in seconds, so you need to divide by 3600 to get the number of hours (e.g. 86,400 seconds = 24 hours). This is the amount of time that you need to wait between now and when you actually move your domain.

  4. Adjust your TTL to its shortest setting. For example, 300 seconds is equal to 5 minutes, so that’s a good choice if it’s available.

  5. Wait out the original TTL from Step 3 before actually moving your domain–otherwise, DNS caching servers will not know of the new, lower TTL yet.

Use Linode’s Nameservers

  1. Follow Linode’s instructions on adding a domain zone to create DNS records at Linode for your domain. Recreate the DNS records listed in your current nameserver authority’s website, but change the IP addresses to reflect your Linode IPs where appropriate.

  2. Locate your domain’s registrar, which is the company you purchased your domain from. If you’re not sure who your registrar is, you can find out with a Whois Search tool.

    Your registrar may not be the same organization as your current nameserver authority, though they often are, as registrars generally offer free DNS services.

  3. Log in to your domain registrar’s control panel and update the authoritative nameservers to be Linode’s nameservers:

    • ns1.linode.com
    • ns2.linode.com
    • ns3.linode.com
    • ns4.linode.com
    • ns5.linode.com

    The following support documents describe how to update the authoritative nameservers of common registrars:

  4. Wait the amount of time you set for your TTL for the domain to propagate. If you did not shorten your TTL, this may take up to 48 hours.

  5. Navigate to your domain in a web browser. It should now show the website from Linode, rather than your old host. If you can’t tell the difference, use the DIG utility. It should show the IP address for your Linode.

  6. Set reverse DNS for your domain. This is especially important if you are running a mail server.

    Note
    If you’re having trouble seeing your site at the new IP address, try visiting it in a different browser or in a private browsing session. Sometimes your browser will cache old DNS data, even if it has updated everywhere else.

Update WHM Hostname

After your DNS changes have propagated, update WHM’s hostname to be your domain. In the menu on the left side of the WHM dashboard, navigate to the Networking Setup section and choose the Change Hostname option. Enter the new hostname in the form that appears and click the Change button:

Transfer cPanel License

If you purchased your license directly from cPanel, update your license to feature your new Linode’s IP address. If you purchased your license through your previous host, then you will need to purchase a new license from cPanel for your Linode deployment. As an alternative to purchasing from cPanel, a free cPanel subscription is included for each of your Linodes if you are a Linode Managed subscriber.

More Information

You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.

This page was originally published on


Your Feedback Is Important

Let us know if this guide was helpful to you.


Join the conversation.
Read other comments or post your own below. Comments must be respectful, constructive, and relevant to the topic of the guide. Do not post external links or advertisements. Before posting, consider if your comment would be better addressed by contacting our Support team or asking on our Community Site.
The Disqus commenting system for Linode Docs requires the acceptance of Functional Cookies, which allow us to analyze site usage so we can measure and improve performance. To view and create comments for this article, please update your Cookie Preferences on this website and refresh this web page. Please note: You must have JavaScript enabled in your browser.