This section describes the features of different types of backup.

Physical (original) and logical backups

A physical backup consists of an original copy of the directory and files that store the contents of the database. This type of backup is suitable for large and important databases that need to be recovered quickly in the event of a problem. Logical backups hold information represented as logical DATABASE structure (CREATE DATABASE, CREATE TABLE statement) and content (INSERT statement or delimited text file). This type of backup is suitable for small amounts of data where you might edit data values or table structures, or recreate data on a different computer architecture. The physical backup method has the following features:

  • A backup consists of an exact copy of the database directory and files. Usually this is a copy of all or part of the MySQL data directory.
  • Physical backup methods are faster than logic because they only involve copying files without conversion.
  • Output is more compact than logical backup.
  • Because backup speed and compactness are important for busy, important databases, MySQL Enterprise Backup products can perform physical backups. For an overview of MySQL Enterprise backup products, see Section 29.2, “overview of MySQL Enterprise Backup.”
  • Backup and restore ranges in granularity from the entire data directory level to the individual file level. This may or may not provide table-level granularity, depending on the storage engine. For example, InnoDB tables can be placed in a separate file or shared with other InnoDB tables. Each MyISAM table corresponds to a unique set of files.
  • In addition to databases, backups can contain any related files, such as logs or configuration files.
  • Data from MEMORY tables is difficult to back up in this way because their contents are not stored on disk. (MySQL Enterprise backup product has the ability to retrieve data from tables in MEMORY during backup.)
  • Backups can only be ported to other machines with the same or similar hardware features.
  • Backups can be performed when the MySQL server is not running. If the server is running, you need to perform appropriate locking so that the server does not change the database contents during the backup. MySQL Enterprise Backup automatically performs this lock for tables that require it.
  • Physical Backup tools include MySQL Enterprise Backup or mysqlBackup for any other table, InnoDB or table file system level commands (such as cp, SCP, tar, rsync) MyISAM.
  • To recover:
    • MySQL enterprise backup restores InnoDB and other backup tables.
    • Ndb_restore Restores the NDB table.
    • Files copied at the file system level can be copied back to their original location using the file system command.

The logical backup method has the following characteristics:

  • Backup is to query the MySQL server for database structure and content information.
  • Backup is slower than physical methods because the server must access the database information and convert it to a logical format. If the output is written to the client, the server must also send it to the backup program.
  • The output is larger than the physical backup, especially if saved in text format.
  • Backup and restore granularity can be used at the server level (all databases), database level (all tables in a particular database), or table level. This is true regardless of the storage engine.
  • Backups do not include logs or configuration files, or other database-related files that do not belong to the database.
  • Backups stored in logical format are machine-independent and portable.
  • The logical backup is performed with the MySQL server running. The server is not offline.
  • Logical backup tools include mysqldump and SELECT… INTO OUTFILE statement. These apply to any storage engine, even MEMORY.
  • To restore the logical backup, you can use the mysql client to process the dump file in SQL format. To LOAD delimited text files, use the LOAD DATA INFILE statement or the mysqlimport client.

Online and offline backup

While the MySQL server is running, an online backup occurs so that database information can be retrieved from the server. Offline backup occurs when the server is stopped. This distinction can also be described as “hot” versus “cold” backups; A “warm” backup is one that stays running on the server, but is locked to prevent modifying data when you access database files from outside. The online backup method has the following characteristics:

  • Backups of other clients have less impact on other clients, who can connect to the MySQL server during backups and access data as they need to perform operations.
  • Care must be taken to apply appropriate locking so that data changes do not occur that compromise backup integrity. MySQL Enterprise backup products automatically do this locking.

The offline backup method has the following characteristics:

  • Clients may be adversely affected because the server is not available during the backup process. For this reason, such backups are typically taken from replica slave servers and can be taken offline without affecting availability.
  • The backup program is simpler because client activity cannot be disrupted.

A similar distinction between online and offline applies to recovery operations, and similar characteristics apply. However, online recovery is more likely to affect clients than online backup because recovery requires stronger locking. During a backup, clients may read data while backing up data. Restoring modified data is not just about reading data, so clients must prevent access to data during recovery.

Local and remote backup

Local backups are performed on the same host running the MySQL server, while remote backups are done from different hosts. For some types of backup, you can start a backup from a remote host even if the output is written locally on the server. The host.

  • Mysqldump can connect to local or remote servers. For SQL output (CREATE and INSERT statements), local or remote dumps can be done and the output generated on the client side. For delimited text output (using the — TAB option), data files are created on the server host.
  • SELECT … INTO OUTFILE can be started from a local or remote client host, but the output file is created on the server host.
  • The physical backup method is typically started locally on the MySQL server host so that the server can go offline, although the target for copying files may be remote.

The snapshot backup

Some file system implementations are capable of “snapshots”. They provide a logical copy of the file system at a given point in time, rather than requiring a physical copy of the entire file system. (For example, an implementation can use a copy-on-write technique to modify only certain parts of the file system after the snapshot time has been copied.).MySQL itself does not provide the capability to take a snapshot of the file system. It is available through third-party solutions such as Veritas, LVM or ZFS.

Full with incremental backup

A full backup includes all data managed by the MySQL server at a specific point in time. Incremental backups include changes made to data over a given span of time, from one point in time to another. MySQL has different ways to perform a full backup, as described earlier in this section. Incremental backup can be achieved by enabling the binary logging that the server uses to record changes to the data.

Full and point-in-time (incremental) recovery

Full recovery restores all the data in the full backup. This restores the server instance to the state it was in when it was backed up. If this state is insufficient, incremental backups made since the full backup can be restored after a full recovery to put the server in an updated state. Incremental recovery is the recovery of changes made within a given time range. This is also called point-in-time recovery because it brings the state of the server up to a certain amount of time. Point-in-time recovery is based on binary logs and typically restores the server to the state at which it was backed up after the backup files have been fully recovered. The data changes written to the binary log file are then applied as incremental recovery to redo the data changes and bring the server to the desired point in time.

Table maintenance

If the table is corrupted, data integrity may be affected. This is not a typical problem for InnoDB tables. MyISAM if the program checks the form and fixes it if it finds a problem, see section 7.6, MyISAM Form Maintenance and Recovery.

Backup scheduling, compression and encryption

Backup plans are important for automating the backup process. Compressing backup output reduces space requirements, and encrypting the output provides better security against unauthorized access to backup data. MySQL itself does not provide these features. MySQL Enterprise backup products can compress InnoDB backups, and file system utilities can be used to compress or encrypt backup output. Other third-party solutions may be available.

Original: www.searchdoc.cn/rdbms/mysql…