DigitalOcean being a cloud infrastructure provider, we need to manage everything from scratch. If you’re a WordPress user and using DigitalOcean, you might have already encountered with the process of installing PHP, MySQL, Apache/Nginx while setting up your droplet. Unlike shared hosting, you will not find any options for the mail server, backups, file manager etc. Everything should be handled ourselves manually. Since setting up the mail server is a real headache, I decided to go with G Suite and for file manager, I’m using Filezilla.
The actual problem starts with backups. When Geek Dashboard is running on shared hosting, I make use of the backup wizard in cPanel and take the regular backups which are not possible with DigitalOcean. To be on safer side I enabled backups option for my droplet which cost me extra $2/month. The downside is DigitalOcean will take a backup for every 7 days and in the worst case, I’ll lose my 7 days data. Still, it is better to lose 7 days data instead of losing my entire site. Everything is going normally until I see a lot of updates on Facebook where people complain about DigitalOcean’s strange behavior. For some reasons, DigitalOcean guys are taking down the production sites and locking access to droplets without any warning or notice. Support of DigitalOcean is poor as everyone knows and we need to wait for hours just to get a reply for our ticket.
If my site is taken down and locked access to the droplet, then what is the use of backups in my droplet? What if they permanently disable the account and refuses to provide backup? Our entire business will go down in split second and irony is we’ll never know why our droplet is taken down and how our business died.
So, I decided to look for few other backup options which will save me even in such situation with zero or less damage. I quickly searched for WordPress backup plugins and satisfied with the features and reviews of UpdraftPlus. I installed it immediately on my live site and Bhoom!
For strange reasons, after installing UpdraftPlus, my site went down with 502 Bad Gateway and
504 Gateway Time-out errors. Later I found my CPU usage is over 100% and something wrong is happening. I logged in using FileZilla and deleted UpdraftPlus plugin and everything comes to normal again.
This time I ditched plugins for backup and decided to go with manual backups. Since I had basic knowledge of Linux commands (Thanks to my computer science degree), I created the backup of my entire site in less than 15 minutes without any plugins. All I have to do is running few lines of Linux commands carefully.
I will show you the simplest method to manually backup database and all website files in DigitalOcean and save them locally on your machine.
Manually create files and database backup in DigitalOcean
We’ll connect to the droplet using the terminal and zip entire html directory and save it to the same directory. We’ll download the zip file using the browser and then delete it from the server. In the same way, we’ll dump the database as SQL file, download it from the browser and finally delete it from the server.
Here is how I manually backup my files and database in DigitalOcean and saved to local machine using Terminal.
Open Terminal (Mac) or Putty (Windows) and connect to your terminal by running the following command and enter the password when prompted.
Your command will look like ssh firstname.lastname@example.org
Navigate to /var/www/html directory using the command
You need to follow this step only when you’re taking backup for the first time. In this step, we’re installing a utility to zip the files. Ignore this step if zip utility is already installed and proceed to step 4.
Run the following commands to install zip utility. Press Y when prompted.
sudo apt install yum
sudo yum install zip
It’s time to take the actual backup by running the following command. It would take 2-10 minutes to zip your entire site depending on the size of files. Don’t panic and stay calm till it does its work
sudo zip -r /var/www/html/files-backup.zip /var/www/html/
Your backup will be saved with name files-backup.zip and you can download the backup file by opening www.domain-name.com/files-backup.zip
For security reasons, you should delete the zip file immediately after downloading the zip file. Run the below command to delete the backup file from the server.
sudo rm files-backup.zip
We have successfully downloaded your entire website files and saved it on the local machine. Still, we need to backup the database to complete the process.
We’ll backup the entire database as an SQL file which can be used to restore again if needed. To backup your database, run the below command with required changes.
sudo mysqldump -u mysql_username -p database_name > database-backup.sql
Before running this command, make sure you change mysql_username and database_name you need to backup. Along with them you also need to enter the MySQL password (if any) when prompted.
You can get all these 3 details from your wp-config.php file. To open it, run
sudo nano wp-config.php command
Download the database backup by opening www.domain-name.com/database-backup.sql from your browser.
Again for security reasons, you need to delete the database-backup.sql file by running the following command
sudo rm database-backup.sql
That’s it you’re done manually taking backup of files and database from DigitaOcean droplet. Log out and close the terminal.
Make sure you deleted both files from the server by opening www.domain-name.com/files-backup.zip and www.domain-name.com/database-backup.sql where both URL’s will land you in 404 page.
Repeat all steps except Step 3 every day for regular backups.
You can also upload those two files to Dropbox or Google Drive for better safety.
Hope this guide will help you to manually backup files and database from DigitalOcean server without any plugin. If you find any problems while running above commands, drop a comment below and I’ll help you in fixing the problem.