Backing up and restoring a MySQL database via SSH

Backing up a MySQL database and restoring via SSH

1/ This tutorial will show you how the steps for backing up a MySQL database via SSH

Sometimes a MySQL database is simply too large to backup on a web based interface. In the event of this occurring, it is fairly easy to backup a database via SSH; all it takes is one command. This tutorial will show you how.

First of all, login to SSH either as root or elevate yourself to root status.

mysqldump -u user -p password -h host dbname > outputfile

The terms highlighted in bold need to be filled out by you. A brief overview of what they are:

  • user: The user that has access to the database you want to backup
  • password: The password of that user
  • host: Your database host; usually setting this to localhost works fine
  • dbname: The name of the database you want to backup
  • outputfile: The name of the file you want to backup the database to.

Here is an example:

mysqldump -u john -p johnpass -h localhost john_db > /home/john/backup.sql

This will backup the database john_db to /home/john/backup.sql. Keep in mind for very large files, this will take some time, so be patient. Once it is finished, you will be returned to the command line and that’s all regarding backing up a mysql database.

2/ This tutorial will show you how to restore a MySQL database via SSH

Sometimes you will have a database backup that is too big to restore over a web interface. The best way to restore large SQL backups is through SSH, and all it takes is one command. This tutorial will show you how.

First of all, connect to your server via SSH and login as root/elevate yourself to root status. Here is the command we are going to use:

mysql -u user -p password -h host database_name < backupfile.sql

You need to change the bold sections. A brief explanation of each:

  • user: The user who has access to the database you are importing data into
  • password: Password of the user
  • host: The database host. This is usually localhost
  • database_name: Name of the database you want to import data into
  • backupfile.sql – Name/location of the backup file you want to import.

Here is a proper example:

mysql -u john -p johnspass -h localhost johns_db < /home/john/backups/backup.sql

In this example, we are importing the file backup.sql into the database johns_db, using the user john, and the database host is localhost.

This could take a while depending on the size of the database. Once you are returned to the command line, the import has been completed. It is a good idea to check in phpMyAdmin or a similar tool to make sure that the database imported correctly.

That’s all regarding backing up a mysql database via SSH

Backing up a MySQL database is an essential practice to ensure the safety and integrity of your data. By creating regular backups, you can protect against data loss, system failures, and human errors. Here are the steps to back up a MySQL database:

1. Identify the database:

Determine the name of the database you want to back up. You can use the following command in the MySQL command-line interface:

2. Choose a backup method:

There are different ways to back up a MySQL database, including using command-line tools, graphical interfaces, or automation scripts. One common method is to use the mysqldump command-line utility, which is usually bundled with MySQL.

3. Use mysqldump to create a backup:

Open a terminal or command prompt and execute the following command to create a backup of your database:
mysqldump -u [username] -p [database_name] > [backup_file.sql] “`
Replace `[username]` with your MySQL username, `[database_name]` with the name of the database you want to back up, and `[backup_file.sql]` with the desired filename for your backup file. You will be prompted to enter your MySQL password.

4. Verify the backup:

Once the backup process is complete, you can verify its success by checking the size and contents of the backup file.

5. Store the backup securely:

It is crucial to store your backup files in a secure location, preferably on a separate server or external storage device. Basically, this ensures that your backups are protected in case of system failures or data breaches.

6. Automate the backup process:

To ensure regular and consistent backups, consider automating the backup process. You can use cron jobs (on Unix-like systems) or task scheduler (on Windows) to schedule periodic backups.

Remember to test the backup restoration process periodically to ensure that your backups are valid and can be successfully restored when needed. Additionally, it is recommended to implement a backup retention policy to manage and rotate backups based on your specific requirements.

By following these steps and maintaining a regular backup routine, you can safeguard your MySQL database and minimize the risk of data loss.


Previous Post
Optimize WordPress Performance
Next Post
Keeping your Linux server up to date

Get Online Today!


Your perfect domain name is waiting!

Search our huge portfolio for more domain name extensions and pricing below
domain name extensions

Classic Domain Names

.COM | .AU | .CO | .NET | .BIZ | .ME | .EU | .ASIA | .TV | .MOBI | .NAME | .INFO | .ORG | .US | .NL| .FM | .HK | .ES | .CO.NZ | .DE | .CO.UK | .RU | .IM | .PM | .TW | .FR | .CN | .CA | .CH | .VN | .PL | .IL | .JP | .KR |