Backup and Recovery in MySQL Database



     It is important to back up your databases so that you can recover your data and be up and running again in case problems occur, such as system crashes, hardware failures, or users deleting data by mistake.

Types of Backup:

logical backup
This type of backup is created by saving information that represents the logical database structures using SQL statements like create database, create table and insert. This type of backup is ideal when you want to upgrade from one version of MySQL to another however it is a slower method of backing up.
physical backup
This type of backup is a backup of the actual database files or disk partitions, this type of backup can be very fast to backup and restore.
full backup
A full backup is a standalone backup containing everything in the database, this could then be restored on another server. A full backup can be either logical or physical.
incremental backup
This type of backup only contains the data that has changed from the last backup. The advantage of this type of backup is that it is faster as there is not some much data to backup, however the disadvantage is that it takes longer to recover.
consistent backup
This is a backup at an exact moment in time, generally you shutdown the database (or quiescent mode) then take the backup.
hot backup
This type of backup is taken when the database is running, during the backup both reads and writes are not blocked
warm backup
This type of backup is taken when the database is running, however reads are not blocked but writes are prohibited from making any modifications to the database.
cold backup
Similar to a consistent backup as the database is shutdown before the backup begins
point-in-time restore
It is a restoration of a database to a specified date and time , some databases use a full backup and recovery logs to restore to that point-in-time, others can only use the last full backup which means that data might have to be re-keyed into the system.

 Types of Backup tools:

Backup tools for MySQL
Backup method
Storage engine
Impact
Backup speed
Recovery speed
Recovery granularity
mysqldump
ALL
WARM
MEDUIM
SLOWEST
MOST FLEXIBLE
mysqldump
INNODB
HOT
MEDUIM
SLOWEST
MOST FLEXIBLE
select into outfile
ALL
WARM
SLOW
SLOW
MOST FLEXIBLE
mk-parallel-backup
ALL
WARM
MEDUIM
MEDUIM
FLEXIBLE
ibbackup
INNODB
HOT
FAST
FAST
FLEXIBLE
ibbackup
ALL
WARM
FAST
FAST
FLEXIBLE
backup command in mysqld
ALL
HOT
FAST
FAST
FLEXIBLE
filesystem (copy files)
ALL
COLD
FASTEST
FASTEST
NOT FLEXIBLE
snapshot (using LVM, ZFS, VMWare)
ALL
ALMOST HOT
FAST
FAST
LEAST FLEXIBLE
mysqlhotcopy
MyISAM
MOSTLY COLD
FAST
FAST
FLEXIBLE

MySQLdump:

     mysqldump is an effective tool to backup MySQL database. It creates a *.sql file with DROP table, CREATE table and INSERT into sql-statements of the source database. To restore the database,  execute the *.sql file on destination database.  
mysqldump
# backup all databases
mysqldump --user=root --password --all-databases > backup_<date>_all.sql

# backup a specific database
mysqldump --user=root --password <database_name> > backup_<date>_<database_name>.sql
# backup multiple databases
mysqldump --user=root --password <database_name>,<database_name> > backup_<date>.sql

# backup a table from a database
mysqldump --user=root --password <database_name> <table_name> > backup_<date>_<database_name>_<table_name>.sql
# backup some specific data
mysqldump --user=root --password <database_name> <table_name> --where "last_name='VALLE' order by first_name > backup_<date>.sql
# dumping from one database to another
mysqldump --databases <database_name> | mysql -h <destination_host> <database_name>
restore a mysqldump
# all databases
mysql --user=root --password < backup.sql

# specific database
mysql --user=<user> --password <database_name> < backup_<dataabse_name>.sql

SELECT INTO OUTFILE

     The SELECT INTO OUTFILE SQL statement is actually a variant of the SELECT query. It is used when you want to direct query output to a text file. This file can then be opened by a spreadsheet application, or imported into another database like Microsoft Access, Oracle, or any other software that supports delimitation.
Ex
SELECT id, data INTO @x, @y FROM test.t1 LIMIT 1;

LOAD DATA INFILE 
  
The 
LOAD DATA INFILE statement reads rows from a text file into a table at a very high speed. The file name must be given as a literal string. 

Ex
LOAD DATA INFILE 'data.txt' INTO TABLE db2.my_table;

mysqlhotcopy

mysqlhotcopy is a Perl script that was originally written and contributed by Tim Bunce. It uses 
FLUSH TABLESLOCK TABLES, and cp or scp to make a database backup. It is a fast way to make a backup of the database or single tables, but it can be run only on the same machine where the database directories are located. mysqlhotcopy works only for backing up MyISAM and ARCHIVE tables.

Ex

#backup a database
mysqlhotcopy <database_name> /backups

# backup multiple databases
mysqlhotcopy <database_name> accounts /backups

#backup a database to to another server
mysqlhotcopy --method=scp <database_name> \ username@backup.server:/backup


# use pattern match to backup databases and tables
mysqlhotcopy <database_name>./^employees/ /backup

10 Ways to Automatically & Manually Backup MySQL Database


Comments

Popular posts from this blog

PostgreSQL Database Version 13.4 To MySQL Database Version 8.0.20 Migration by using SQLines Tool

MariaDB Database Multi-instance implementation in single machine