1XTRABACKUP(1)                 Percona XtraBackup                 XTRABACKUP(1)
2
3
4

NAME

6       xtrabackup - Percona XtraBackup 2.3 Documentation
7
8       The  xtrabackup  binary is a compiled C program that is linked with the
9       InnoDB libraries and the standard MySQL client  libraries.  The  InnoDB
10       libraries provide functionality necessary to apply a log to data files,
11       and the MySQL client libraries  provide  command-line  option  parsing,
12       configuration  file  parsing,  and  so on to give the binary a familiar
13       look and feel.
14
15       The tool runs in either --backup or --prepare  mode,  corresponding  to
16       the  two  main  functions  it performs. There are several variations on
17       these functions to accomplish different tasks, and there are  two  less
18       commonly used modes, --stats and --print-param.
19

THE BACKUP CYCLE - FULL BACKUPS

21   Creating a Backup
22       To  create  a backup, run xtrabackup with the --backup option. You also
23       need to specify a --target_dir option, which is where the  backup  will
24       be  stored,  and  a  --datadir option, which is where the MySQL data is
25       stored. If the InnoDB data or log  files  aren't  stored  in  the  same
26       directory, you might need to specify the location of those, too. If the
27       target directory does not exist, xtrabackup creates it. If  the  direc‐
28       tory  does exist and is empty, xtrabackup will succeed. xtrabackup will
29       not overwrite existing files, it will fail with operating system  error
30       17,  file exists.
31
32       The  tool  changes its working directory to the data directory and per‐
33       forms two primary tasks to complete the backup:
34
35       · It starts a log-copying thread in the background. This thread watches
36         the  InnoDB  log  files,  and when they change, it copies the changed
37         blocks to a file  called  xtrabackup_logfile  in  the  backup  target
38         directory.  This  is  necessary  because the backup might take a long
39         time, and the recovery process needs all of the log file entries from
40         the beginning to the end of the backup.
41
42       · It  copies the InnoDB data files to the target directory. This is not
43         a simple file copy; it opens and reads the files similarly to the way
44         InnoDB  does,  by reading the data dictionary and copying them a page
45         at a time.
46
47       When  the  data  files  are  finished  copying,  xtrabackup  stops  the
48       log-copying  thread, and creates a files in the target directory called
49       xtrabackup_checkpoints, which contains the type  of  backup  performed,
50       the  log  sequence number at the beginning, and the log sequence number
51       at the end.
52
53       An example command to perform a backup follows:
54
55          $ xtrabackup --backup --datadir=/var/lib/mysql/ --target-dir=/data/backups/mysql/
56
57       This takes a backup of /var/lib/mysql  and  stores  it  at  /data/back‐
58       ups/mysql/.  If  you specify a relative path, the target directory will
59       be relative to the current directory.
60
61       During the backup process, you should see a lot of output  showing  the
62       data  files  being  copied,  as  well as the log file thread repeatedly
63       scanning the log files and copying from it. Here  is  an  example  that
64       shows  the  log  thread  scanning the log in the background, and a file
65       copying thread working on the ibdata1 file:
66
67          >> log scanned up to (3646475465483)
68          >> log scanned up to (3646475517369)
69          >> log scanned up to (3646475581716)
70          >> log scanned up to (3646475636841)
71          >> log scanned up to (3646475718082)
72          >> log scanned up to (3646475988095)
73          >> log scanned up to (3646476048286)
74          >> log scanned up to (3646476102877)
75          >> log scanned up to (3646476140854)
76          [01] Copying /usr/local/mysql/var/ibdata1
77               to /usr/local/mysql/Backups/2011-04-18_21-11-15/ibdata1
78          [01]        ...done
79
80       The last thing you should see is something like  the  following,  where
81       the value of the <LSN> will be a number that depends on your system:
82
83          xtrabackup: Transaction log of lsn (<SLN>) to (<LSN>) was copied.
84
85       NOTE:
86          Log  copying thread checks the transactional log every second to see
87          if there were any new log records written that need  to  be  copied,
88          but  there is a chance that the log copying thread might not be able
89          to keep up with the amount of writes that go  to  the  transactional
90          logs,  and  will  hit  an error when the log records are overwritten
91          before they could be read.
92
93       After the backup is finished, the target directory will  contain  files
94       such  as  the  following,  assuming  you  have  a  single  InnoDB table
95       test.tbl1 and you are using MySQL's innodb_file_per_table option:
96
97          /data/backups/mysql/ibdata1
98          /data/backups/mysql/test
99          /data/backups/mysql/test/tbl1.ibd
100          /data/backups/mysql/xtrabackup_checkpoints
101          /data/backups/mysql/xtrabackup_logfile
102
103       The backup can take a long time, depending on how  large  the  database
104       is.  It  is  safe to cancel at any time, because it does not modify the
105       database.
106
107       The next step  is  getting  your  backup  ready  to  restored:  prepar‐
108       ing_the_backup.
109
110   Preparing the backup
111       After  you make a backup with --backup, the next step is to prepare it.
112       The data files are not point-in-time consistent until they've been pre‐
113       pared,  because they were copied at different times as the program ran,
114       and they might have been changed while this was happening. If  you  try
115       to  start  InnoDB  with these data files, it will detect corruption and
116       crash itself to prevent you from running on damaged data. The --prepare
117       step  makes the files perfectly consistent at a single instant in time,
118       so you can run InnoDB on them.
119
120       NOTE:
121          For prepare innobackupex --apply-log should be used which will  read
122          InnoDB    configuration   from   backup-my.cnf   automatically,   or
123          --defaults-file=backup-my.cnf option should be passed to  the  xtra‐
124          backup  binary  if it is used for preparing the backup. Otherwise it
125          could lead to incorrect restore because xtrabackup could  use  wrong
126          configuration options.
127
128       You  can  run the prepare operation on any machine; it does not need to
129       be on the originating server or the  server  to  which  you  intend  to
130       restore.  You  can  copy  the backup to a utility server and prepare it
131       there, for example.
132
133       NOTE:
134          You can prepare a backup created with older Percona XtraBackup  ver‐
135          sion  with a newer one, but not vice versa. Preparing a backup on an
136          unsupported server version should be done with  the  latest  Percona
137          XtraBackup  release which supports that server version. For example,
138          if one has a backup of MySQL 5.0  created  with  Percona  XtraBackup
139          1.6,  then  preparing  the backup with Percona XtraBackup 2.2 is not
140          supported, because  support  for  MySQL  5.0  was  removed  in  2.1.
141          Instead, the latest release in the 2.0 series should be used.
142
143       During  the  prepare  operation, xtrabackup boots up a kind of modified
144       InnoDB that's embedded inside it (the libraries it was linked against).
145       The  modifications  are  necessary  to disable InnoDB's standard safety
146       checks, such as complaining that the log file  isn't  the  right  size,
147       which  aren't appropriate for working with backups. These modifications
148       are only for the xtrabackup binary; you don't need a modified InnoDB to
149       use xtrabackup for your backups.
150
151       The  prepare step uses this "embedded InnoDB" to perform crash recovery
152       on the copied datafiles, using the copied log file. The prepare step is
153       very simple to use: you simply run xtrabackup with the --prepare option
154       and tell it which directory to prepare, for  example,  to  prepare  the
155       backup previously taken,
156
157          xtrabackup --prepare --target-dir=/data/backups/mysql/
158
159       When  this finishes, you should see an "InnoDB shutdown" with a message
160       such as the following, where again the value of LSN will depend on your
161       system:
162
163          101107 16:40:15  InnoDB: Shutdown completed; log sequence number <LSN>
164
165       Your backup is now clean and consistent, and ready to restore. However,
166       you might want to take an extra step to make restores as quick as  pos‐
167       sible.  This  is  to  prepare  the backup a second time. The first time
168       makes the data files perfectly self-consistent, but it  doesn't  create
169       fresh  InnoDB  log  files.  If you restore the backup at this point and
170       start MySQL, it will have to create new log files, which could  take  a
171       little  while,  and  you  might  not  want to wait for that. If you run
172       --prepare a second time, xtrabackup will create the log files for  you,
173       and  output status text such as the following, which is abbreviated for
174       clarity. The value of <SIZE> will depend on your MySQL configuration.
175
176          $ xtrabackup --prepare --target-dir=/data/backups/mysql/
177          xtrabackup: This target seems to be already prepared.
178          xtrabackup: notice: xtrabackup_logfile was already used to '--prepare'.
179          101107 16:54:10  InnoDB: Log file ./ib_logfile0 did not exist: new to be created
180          InnoDB: Setting log file ./ib_logfile0 size to <SIZE> MB
181          InnoDB: Database physically writes the file full: wait...
182          101107 16:54:10  InnoDB: Log file ./ib_logfile1 did not exist: new to be created
183          InnoDB: Setting log file ./ib_logfile1 size to <SIZE> MB
184          InnoDB: Database physically writes the file full: wait...
185          101107 16:54:15  InnoDB: Shutdown completed; log sequence number 1284108
186
187       All following prepares  (third  and  following)  will  not  change  the
188       already prepared data files, you can only see that output says
189
190          xtrabackup: This target seems to be already prepared.
191          xtrabackup: notice: xtrabackup_logfile was already used to '--prepare'.
192
193       It  is  not recommended to interrupt xtrabackup process while preparing
194       backup - it may cause data files corruption and backup will become  not
195       usable. Backup validity is not guaranteed if prepare process was inter‐
196       rupted.
197
198       If you intend the backup to be the basis for further incremental  back‐
199       ups,  you  should  use  the  --apply-log-only option when preparing the
200       backup, or you will not be able to apply incremental backups to it. See
201       the documentation on preparing incremental backups for more details.
202
203   Restoring a Backup
204       The  xtrabackup  binary does not have any functionality for restoring a
205       backup. That is up to the user to do. You might  use  rsync  or  cp  to
206       restore  the  files.  You should check that the restored files have the
207       correct ownership and permissions.
208
209       NOTE:
210          The datadir must be empty before restoring  the  backup.  Also  it's
211          important  to  note  that  MySQL server needs to be shut down before
212          restore is performed. You can't restore to a datadir  of  a  running
213          mysqld instance (except when importing a partial backup).
214
215       Example of the rsync command that can be used to restore the backup can
216       look like this:
217
218          $ rsync -avrP /data/backup/ /var/lib/mysql/
219
220       As files' attributes will be preserved, in most cases you will need  to
221       change  the  files'  ownership  to  mysql  before starting the database
222       server, as they will be owned by the user who created the backup:
223
224          $ chown -R mysql:mysql /var/lib/mysql
225
226       Note that xtrabackup backs up only the InnoDB data. You must separately
227       restore  the MySQL system database, MyISAM data, table definition files
228       (.frm files), and everything else necessary to make your database func‐
229       tional -- or innobackupex can do it for you.
230

OTHER TYPES OF BACKUPS

232   Incremental Backups
233       Both  xtrabackup  and  innobackupex tools supports incremental backups,
234       which means that it can copy only the data that has changed  since  the
235       last full backup. You can perform many incremental backups between each
236       full backup, so you can set up a backup process such as a  full  backup
237       once  a week and an incremental backup every day, or full backups every
238       day and incremental backups every hour.
239
240       Incremental backups work because each  InnoDB  page  (usually  16kb  in
241       size)  contains  a  log  sequence number, or LSN. The LSN is the system
242       version number for the entire  database.  Each  page's  LSN  shows  how
243       recently  it  was changed. An incremental backup copies each page whose
244       LSN is newer than the previous incremental or full backup's LSN.  There
245       are  two  algorithms in use to find the set of such pages to be copied.
246       The first one, available with all the server types and versions, is  to
247       check  the  page LSN directly by reading all the data pages. The second
248       one, available with Percona Server,  is  to  enable  the  changed  page
249       tracking  feature  on the server, which will note the pages as they are
250       being changed. This information will be then written out in  a  compact
251       separate  so-called  bitmap  file.  The xtrabackup binary will use that
252       file to read only the data pages it needs for the  incremental  backup,
253       potentially  saving many read requests. The latter algorithm is enabled
254       by default if the xtrabackup binary finds the bitmap file. It is possi‐
255       ble  to  specify --incremental-force-scan to read all the pages even if
256       the bitmap data is available.
257
258       Incremental backups do not actually compare the data files to the  pre‐
259       vious  backup's  data  files. In fact, you can use --incremental-lsn to
260       perform an incremental backup without even having the previous  backup,
261       if you know its LSN. Incremental backups simply read the pages and com‐
262       pare their LSN to the last backup's LSN. You still need a  full  backup
263       to  recover  the incremental changes, however; without a full backup to
264       act as a base, the incremental backups are useless.
265
266   Creating an Incremental Backup
267       To make an incremental backup, begin with a full backup as  usual.  The
268       xtrabackup  binary writes a file called xtrabackup_checkpoints into the
269       backup's target directory.  This  file  contains  a  line  showing  the
270       to_lsn,  which  is  the database's LSN at the end of the backup. Create
271       the full backup with a command such as the following:
272
273          xtrabackup --backup --target-dir=/data/backups/base --datadir=/var/lib/mysql/
274
275       If you want a usable full backup,  use  innobackupex  since  xtrabackup
276       itself  won't copy table definitions, triggers, or anything else that's
277       not .ibd.
278
279       If you look at the xtrabackup_checkpoints file,  you  should  see  some
280       contents similar to the following:
281
282          backup_type = full-backuped
283          from_lsn = 0
284          to_lsn = 1291135
285
286       Now  that  you  have  a full backup, you can make an incremental backup
287       based on it. Use a command such as the following:
288
289          xtrabackup --backup --target-dir=/data/backups/inc1 \
290          --incremental-basedir=/data/backups/base --datadir=/var/lib/mysql/
291
292       The /data/backups/inc1/ directory should now contain delta files,  such
293       as ibdata1.delta and test/table1.ibd.delta. These represent the changes
294       since the LSN 1291135. If you examine the  xtrabackup_checkpoints  file
295       in this directory, you should see something similar to the following:
296
297          backup_type = incremental
298          from_lsn = 1291135
299          to_lsn = 1291340
300
301       The  meaning  should  be  self-evident.  It's  now possible to use this
302       directory as the base for yet another incremental backup:
303
304          xtrabackup --backup --target-dir=/data/backups/inc2 \
305          --incremental-basedir=/data/backups/inc1 --datadir=/var/lib/mysql/
306
307   Preparing the Incremental Backups
308       The --prepare step for incremental backups is not the same as for  nor‐
309       mal  backups.  In normal backups, two types of operations are performed
310       to make the database consistent: committed  transactions  are  replayed
311       from  the log file against the data files, and uncommitted transactions
312       are rolled back. You must skip the rollback of uncommitted transactions
313       when  preparing a backup, because transactions that were uncommitted at
314       the time of your backup may be in progress, and it's likely  that  they
315       will  be  committed  in the next incremental backup. You should use the
316       --apply-log-only option to prevent the rollback phase.
317
318       If you do not use the --apply-log-only option to prevent  the  rollback
319       phase,  then  your  incremental backups will be useless. After transac‐
320       tions have been rolled back,  further  incremental  backups  cannot  be
321       applied.
322
323       Beginning  with  the  full  backup you created, you can prepare it, and
324       then apply the incremental differences to it. Recall that you have  the
325       following backups:
326
327          /data/backups/base
328          /data/backups/inc1
329          /data/backups/inc2
330
331       To  prepare  the  base  backup, you need to run --prepare as usual, but
332       prevent the rollback phase:
333
334          xtrabackup --prepare --apply-log-only --target-dir=/data/backups/base
335
336       The output should end with some text such as the following:
337
338          101107 20:49:43  InnoDB: Shutdown completed; log sequence number 1291135
339
340       The log sequence number should match the to_lsn  of  the  base  backup,
341       which you saw previously.
342
343       This  backup  is  actually  safe  to restore as-is now, even though the
344       rollback phase has been skipped. If you restore  it  and  start  MySQL,
345       InnoDB  will  detect  that the rollback phase was not performed, and it
346       will do that in the background, as it usually does for a crash recovery
347       upon start. It will notify you that the database was not shut down nor‐
348       mally.
349
350       To apply the first incremental backup to the full  backup,  you  should
351       use the following command:
352
353          xtrabackup --prepare --apply-log-only --target-dir=/data/backups/base \
354          --incremental-dir=/data/backups/inc1
355
356       This  applies the delta files to the files in /data/backups/base, which
357       rolls them forward in time to the time of the  incremental  backup.  It
358       then  applies the redo log as usual to the result. The final data is in
359       /data/backups/base, not in the incremental directory.  You  should  see
360       some output such as the following:
361
362          incremental backup from 1291135 is enabled.
363          xtrabackup: cd to /data/backups/base/
364          xtrabackup: This target seems to be already prepared.
365          xtrabackup: xtrabackup_logfile detected: size=2097152, start_lsn=(1291340)
366          Applying /data/backups/inc1/ibdata1.delta ...
367          Applying /data/backups/inc1/test/table1.ibd.delta ...
368          .... snip
369          101107 20:56:30  InnoDB: Shutdown completed; log sequence number 1291340
370
371       Again,  the  LSN should match what you saw from your earlier inspection
372       of the  first  incremental  backup.  If  you  restore  the  files  from
373       /data/backups/base,  you should see the state of the database as of the
374       first incremental backup.
375
376       Preparing the second incremental backup is a similar process: apply the
377       deltas  to  the (modified) base backup, and you will roll its data for‐
378       ward in time to the point of the second incremental backup:
379
380          xtrabackup --prepare --target-dir=/data/backups/base \
381          --incremental-dir=/data/backups/inc2
382
383       NOTE:
384          --apply-log-only should be used when merging all incrementals except
385          the  last  one.  That's  why  the  previous line doesn't contain the
386          --apply-log-only option. Even if the --apply-log-only  was  used  on
387          the  last  step,  backup  would still be consistent but in that case
388          server would perform the rollback phase.
389
390       If you wish to avoid the notice that InnoDB was not shut down normally,
391       when  you  have  applied the desired deltas to the base backup, you can
392       run --prepare again without disabling the rollback phase.
393
394   Partial Backups
395       xtrabackup supports taking partial backups when the innodb_file_per_ta‐
396       ble  option is enabled. There are three ways to create partial backups:
397       matching the tables' names with a regular expression, providing a  list
398       of them in a file or providing a list of databases.
399
400       WARNING:
401          If any of the matched or listed tables is deleted during the backup,
402          xtrabackup will fail.
403
404       For the purposes of this manual page, we will assume that  there  is  a
405       database named test which contains tables named t1 and t2.
406
407   Using the --tables Option
408       The  first  method is with the --tables option. The option's value is a
409       regular expression that is matched against the fully  qualified  table‐
410       name, including the database name, in the form databasename.tablename.
411
412       To  back up only tables in the test database, you can use the following
413       command:
414
415          $ xtrabackup --backup --datadir=/var/lib/mysql --target-dir=/data/backups/ \
416          --tables="^test[.].*"
417
418       To back up only the table test.t1, you can use the following command:
419
420          $ xtrabackup --backup --datadir=/var/lib/mysql --target-dir=/data/backups/ \
421          --tables="^test[.]t1"
422
423   Using the --tables-file Option
424       The --tables-file option specifies a file that can contain multiple ta‐
425       ble  names,  one table name per line in the file. Only the tables named
426       in the file will be backed up. Names are matched  exactly,  case-sensi‐
427       tive,  with  no pattern or regular expression matching. The table names
428       must be fully qualified, in databasename.tablename format.
429
430          $ echo "mydatabase.mytable" > /tmp/tables.txt
431          $ xtrabackup --backup --tables-file=/tmp/tables.txt
432
433   Using the --databases and --databases-file options
434       The --databases option accepts a space-separated list of the  databases
435       and  tables  to  backup  -  in  the  databasename[.tablename] form. The
436       --databases-file option specifies a  file  that  can  contain  multiple
437       databases  and tables in the databasename[.tablename] form, one element
438       name per line in the file. Only named  databases  and  tables  will  be
439       backed  up.  Names are matched exactly, case-sensitive, with no pattern
440       or regular expression matching.
441
442   Preparing the Backup
443       When you use the --prepare option on a partial  backup,  you  will  see
444       warnings  about  tables  that don't exist. That is because these tables
445       exist in the data dictionary inside InnoDB, but the corresponding  .ibd
446       files  don't  exist.  They  were  not copied into the backup directory.
447       These tables will be removed from the data  dictionary,  and  when  you
448       restore the backup and start InnoDB, they will no longer exist and will
449       not cause any errors or warnings to be printed to the log file.
450
451       An example of the error message you will see during the  prepare  phase
452       follows.
453
454          InnoDB: Reading tablespace information from the .ibd files...
455          101107 22:31:30  InnoDB: Error: table 'test1/t'
456          InnoDB: in InnoDB data dictionary has tablespace id 6,
457          InnoDB: but tablespace with that id or name does not exist. It will be removed from data dictionary.
458
459   Compact Backups
460       When  doing  the backup of InnoDB tables it's possible to omit the sec‐
461       ondary index pages. This will make the backups more  compact  and  this
462       way they will take less space on disk. The downside of this is that the
463       backup prepare process takes longer as those secondary indexes need  to
464       be recreated. Difference in backup size depends on the size of the sec‐
465       ondary indexes.
466
467       For example full backup taken without and with the --compact option:
468
469          #backup size without --compact
470          2.0G  xb_backup
471
472          #backup size taken with --compact option
473          1.4G  xb_compact_backup
474
475       NOTE:
476          Compact backups are not supported for  system  table  space,  so  in
477          order  to  work  correctly  innodb-file-per-table  option  should be
478          enabled.
479
480       This feature was introduced in Percona XtraBackup 2.1.
481
482   Creating Compact Backups
483       To make a compact backup innobackupex needs  to  be  started  with  the
484       --compact option:
485
486          $ xtrabackup --backup --compact --target-dir=/data/backups
487
488       This will create a compact backup in the /data/backups.
489
490       If  you  check  at  the  xtrabackup-checkpoints  file in the target-dir
491       folder, you should see something like:
492
493          backup_type = full-backuped
494          from_lsn = 0
495          to_lsn = 2888984349
496          last_lsn = 2888984349
497          compact = 1
498
499       When --compact wasn't used compact value will be 0. This way it's  easy
500       to check if the backup contains the secondary index pages or not.
501
502   Preparing Compact Backups
503       Preparing  the compact require rebuilding the indexes as well. In order
504       to prepare the backup a new option  --rebuild-indexes  should  be  used
505       with --apply-logs:
506
507          $ xtrabackup --prepare --rebuild-indexes /data/backups/
508
509       Output,  beside  the  standard  innobackupex output, should contain the
510       information about indexes being rebuilt, like:
511
512          [01] Checking if there are indexes to rebuild in table sakila/city (space id: 9)
513          [01]   Found index idx_fk_country_id
514          [01]   Rebuilding 1 index(es).
515          [01] Checking if there are indexes to rebuild in table sakila/country (space id: 10)
516          [01] Checking if there are indexes to rebuild in table sakila/customer (space id: 11)
517          [01]   Found index idx_fk_store_id
518          [01]   Found index idx_fk_address_id
519          [01]   Found index idx_last_name
520          [01]   Rebuilding 3 index(es).
521
522       Additionally, you can  use  the  --rebuild-threads  option  to  process
523       tables in multiple threads when rebuilding indexes, e.g.:
524
525          $ xtrabackup --prepare --rebuild-indexes --rebuild-threads=16 /data/backups/
526
527       In this case Percona XtraBackup will create 16 worker threads with each
528       thread rebuilding indexes for one table at a time. It  will  also  show
529       thread IDs for each message
530
531          Starting 16 threads to rebuild indexes.
532
533          [09] Checking if there are indexes to rebuild in table sakila/city (space id: 9)
534          [09]   Found index idx_fk_country_id
535          [10] Checking if there are indexes to rebuild in table sakila/country (space id: 10)
536          [11] Checking if there are indexes to rebuild in table sakila/customer (space id: 11)
537          [11]   Found index idx_fk_store_id
538          [11]   Found index idx_fk_address_id
539          [11]   Found index idx_last_name
540          [11]   Rebuilding 3 index(es).
541
542       Since  Percona XtraBackup has no information when applying an incremen‐
543       tal backup to a compact full one, on whether there will be more  incre‐
544       mental  backups applied to it later or not, rebuilding indexes needs to
545       be explicitly requested by a user whenever  a  full  backup  with  some
546       incremental  backups merged is ready to be restored. Rebuilding indexes
547       unconditionally on every incremental backup merge  is  not  an  option,
548       since it is an expensive operation.
549
550   Restoring Compact Backups
551       The  xtrabackup  binary does not have any functionality for restoring a
552       backup. That is up to the user to do. You might  use  rsync  or  cp  to
553       restore  the  files.  You should check that the restored files have the
554       correct ownership and permissions.
555
556   Other Reading
557       · Feature preview: Compact backups in Percona XtraBackup
558

ADVANCED FEATURES

560   Throttling Backups
561       Although xtrabackup does  not  block  your  database's  operation,  any
562       backup  can  add load to the system being backed up. On systems that do
563       not have much spare I/O capacity, it might be helpful to  throttle  the
564       rate  at  which  xtrabackup reads and writes data. You can do this with
565       the --throttle option, this option limits the number of I/O  operations
566       per second in 1 MB units.
567
568       Image below shows how throttling works when --throttle =1.  [image]
569
570       In   --backup   mode,  this  option  limits  the  number  of  pairs  of
571       read-and-write operations per second that xtrabackup will  perform.  If
572       you are creating an incremental backup, then the limit is the number of
573       read IO operations per second.
574
575       By default, there is no throttling, and  xtrabackup  reads  and  writes
576       data  as quickly as it can. If you set too strict of a limit on the I/O
577       operations, the backup might be so slow that it  will  never  catch  up
578       with  the  transaction logs that InnoDB is writing, so the backup might
579       never complete.
580
581   Scripting Backups With xtrabackup
582       The xtrabackup tool has several features to enable scripts  to  control
583       it  while  they  perform  related tasks. The innobackupex script is one
584       example, but xtrabackup is easy to control with your  own  command-line
585       scripts too.
586
587   Suspending After Copying
588       In  backup  mode,  xtrabackup  normally copies the log files in a back‐
589       ground thread, copies the data files in a foreground thread,  and  then
590       stops  the  log  copying  thread  and  finishes.  If you use the --sus‐
591       pend-at-end option, instead of stopping the log thread  and  finishing,
592       xtrabackup  continues  to copy the log files, and creates a file in the
593       target directory called xtrabackup_suspended.  As  long  as  that  file
594       exists,  xtrabackup  will continue to watch the log files and copy them
595       into the xtrabackup_logfile in the target directory. When the  file  is
596       removed, xtrabackup will finish copying the log file and exit.
597
598       This  functionality  is useful for coordinating the InnoDB data backups
599       with other actions. Perhaps the most obvious is copying the table defi‐
600       nitions  (the  .frm  files) so that the backup can be restored. You can
601       start xtrabackup in the  background, wait for the  xtrabackup_suspended
602       file  to be created, and then copy any other files you need to complete
603       the backup. This is exactly what the innobackupex tool  does  (it  also
604       copies MyISAM data and other files).
605
606   Generating Meta-Data
607       It  is  a  good  idea for the backup to include all the information you
608       need to restore the backup. The xtrabackup tool can print out the  con‐
609       tents  of  a  my.cnf  file  that are needed to restore the data and log
610       files. If you add the --print-param option, it will print out something
611       like the following:
612
613          # This MySQL options file was generated by XtraBackup.
614          [mysqld]
615          datadir = /data/mysql/
616          innodb_data_home_dir = /data/innodb/
617          innodb_data_file_path = ibdata1:10M:autoextend
618          innodb_log_group_home_dir = /data/innodb-logs/
619
620       You can redirect this output into a file in the target directory of the
621       backup.
622
623   Agreeing on the Source Directory
624       It's possible that the presence of a defaults  file  or  other  factors
625       could  cause  xtrabackup to back up data from a different location than
626       you expected. To prevent this, you can  use  --print-param  to  ask  it
627       where  it  will  be copying data from. You can use the output to ensure
628       that xtrabackup and your script are working on the same dataset.
629
630   Log Streaming
631       You can instruct xtrabackup to omit  copying  data  files,  and  simply
632       stream  the  log file to its standard output instead with --log-stream.
633       This automatically adds the --suspend-at-end option.  Your  script  can
634       then  perform  tasks such as streaming remote backups by piping the log
635       files into an SSH connection and copying  the  data  files  to  another
636       server with a tool such as rsync or the xbstream binary.
637
638   Analyzing Table Statistics
639       The  xtrabackup  binary can analyze InnoDB data files in read-only mode
640       to give statistics about them. To do this, you should use  the  --stats
641       option.  You  can  combine  this  with the --tables option to limit the
642       files to examine. It also uses the --use-memory option.
643
644       You can perform the analysis on a running server, with some  chance  of
645       errors  due to the data being changed during analysis. Or, you can ana‐
646       lyze a backup copy of the database. Either way, to use  the  statistics
647       feature,  you  need  a  clean  copy of the database including correctly
648       sized log files, so you need to execute with  --prepare  twice  to  use
649       this functionality on a backup.
650
651       The result of running on a backup might look like the following:
652
653          <INDEX STATISTICS>
654            table: test/table1, index: PRIMARY, space id: 12, root page 3
655            estimated statistics in dictionary:
656              key vals: 25265338, leaf pages 497839, size pages 498304
657            real statistics:
658               level 2 pages: pages=1, data=5395 bytes, data/pages=32%
659               level 1 pages: pages=415, data=6471907 bytes, data/pages=95%
660                  leaf pages: recs=25958413, pages=497839, data=7492026403 bytes, data/pages=91%
661
662       This can be interpreted as follows:
663
664       · The first line simply shows the table and index name and its internal
665         identifiers. If you see an index named GEN_CLUST_INDEX, that  is  the
666         table's  clustered  index,  automatically created because you did not
667         explicitly create a PRIMARY KEY.
668
669       · The estimated statistics in dictionary information is similar to  the
670         data  that's  gathered  through  ANALYZE TABLE inside of InnoDB to be
671         stored as estimated cardinality statistics and passed  to  the  query
672         optimizer.
673
674       · The  real  statistics  information is the result of scanning the data
675         pages and computing exact information about the index.
676
677       · The level <X> pages: output means that  the  line  shows  information
678         about  pages  at that level in the index tree. The larger <X> is, the
679         farther it is from the leaf pages, which are level 0. The first  line
680         is the root page.
681
682       · The  leaf pages output shows the leaf pages, of course. This is where
683         the table's data is stored.
684
685       · The external pages: output (not shown)  shows  large  external  pages
686         that hold values too long to fit in the row itself, such as long BLOB
687         and TEXT values.
688
689       · The recs is the real number of records (rows) in leaf pages.
690
691       · The pages is the page count.
692
693       · The data is the total size of the data in the pages, in bytes.
694
695       · The data/pages is calculated as (data / (pages * PAGE_SIZE)) *  100%.
696         It  will  never reach 100% because of space reserved for page headers
697         and footers.
698
699       A more detailed example is posted as a MySQL Performance Blog post.
700
701   Script to Format Output
702       The following script can be used to summarize and tabulate  the  output
703       of the statistics information:
704
705          tabulate-xtrabackup-stats.pl
706
707          #!/usr/bin/perl
708          use strict;
709          use warnings FATAL => 'all';
710          my $script_version = "0.1";
711
712          my $PG_SIZE = 16_384; # InnoDB defaults to 16k pages, change if needed.
713          my ($cur_idx, $cur_tbl);
714          my (%idx_stats, %tbl_stats);
715          my ($max_tbl_len, $max_idx_len) = (0, 0);
716          while ( my $line = <> ) {
717             if ( my ($t, $i) = $line =~ m/table: (.*), index: (.*), space id:/ ) {
718                $t =~ s!/!.!;
719                $cur_tbl = $t;
720                $cur_idx = $i;
721                if ( length($i) > $max_idx_len ) {
722                   $max_idx_len = length($i);
723                }
724                if ( length($t) > $max_tbl_len ) {
725                   $max_tbl_len = length($t);
726                }
727             }
728             elsif ( my ($kv, $lp, $sp) = $line =~ m/key vals: (\d+), \D*(\d+), \D*(\d+)/ ) {
729                @{$idx_stats{$cur_tbl}->{$cur_idx}}{qw(est_kv est_lp est_sp)} = ($kv, $lp, $sp);
730                $tbl_stats{$cur_tbl}->{est_kv} += $kv;
731                $tbl_stats{$cur_tbl}->{est_lp} += $lp;
732                $tbl_stats{$cur_tbl}->{est_sp} += $sp;
733             }
734             elsif ( my ($l, $pages, $bytes) = $line =~ m/(?:level (\d+)|leaf) pages:.*pages=(\d+), data=(\d+) bytes/ ) {
735                $l ||= 0;
736                $idx_stats{$cur_tbl}->{$cur_idx}->{real_pages} += $pages;
737                $idx_stats{$cur_tbl}->{$cur_idx}->{real_bytes} += $bytes;
738                $tbl_stats{$cur_tbl}->{real_pages} += $pages;
739                $tbl_stats{$cur_tbl}->{real_bytes} += $bytes;
740             }
741          }
742
743          my $hdr_fmt = "%${max_tbl_len}s %${max_idx_len}s %9s %10s %10s\n";
744          my @headers = qw(TABLE INDEX TOT_PAGES FREE_PAGES PCT_FULL);
745          printf $hdr_fmt, @headers;
746
747          my $row_fmt = "%${max_tbl_len}s %${max_idx_len}s %9d %10d %9.1f%%\n";
748          foreach my $t ( sort keys %tbl_stats ) {
749             my $tbl = $tbl_stats{$t};
750             printf $row_fmt, $t, "", $tbl->{est_sp}, $tbl->{est_sp} - $tbl->{real_pages},
751                $tbl->{real_bytes} / ($tbl->{real_pages} * $PG_SIZE) * 100;
752             foreach my $i ( sort keys %{$idx_stats{$t}} ) {
753                my $idx = $idx_stats{$t}->{$i};
754                printf $row_fmt, $t, $i, $idx->{est_sp}, $idx->{est_sp} - $idx->{real_pages},
755                   $idx->{real_bytes} / ($idx->{real_pages} * $PG_SIZE) * 100;
756             }
757          }
758
759   Sample Script Output
760       The  output of the above Perl script, when run against the sample shown
761       in the previously mentioned blog post, will appear as follows:
762
763                    TABLE           INDEX TOT_PAGES FREE_PAGES   PCT_FULL
764          art.link_out104                    832383      38561      86.8%
765          art.link_out104         PRIMARY    498304         49      91.9%
766          art.link_out104       domain_id     49600       6230      76.9%
767          art.link_out104     domain_id_2     26495       3339      89.1%
768          art.link_out104 from_message_id     28160        142      96.3%
769          art.link_out104    from_site_id     38848       4874      79.4%
770          art.link_out104   revert_domain    153984      19276      71.4%
771          art.link_out104    site_message     36992       4651      83.4%
772
773       The columns are the table and index, followed by the  total  number  of
774       pages in that index, the number of pages not actually occupied by data,
775       and the number of bytes of real data as a percentage of the total  size
776       of the pages of real data. The first line in the above output, in which
777       the INDEX column is empty, is a summary of the entire table.
778
779   Working with Binary Logs
780       The xtrabackup binary integrates with information that InnoDB stores in
781       its  transaction  log  about  the corresponding binary log position for
782       committed transactions. This enables it to print  out  the  binary  log
783       position to which a backup corresponds, so you can use it to set up new
784       replication slaves or perform point-in-time recovery.
785
786   Finding the Binary Log Position
787       You can find the binary log position corresponding to a backup once the
788       backup  has been prepared. This can be done by either running the xtra‐
789       backup with --prepare or innobackupex with --apply-log option. If  your
790       backup  is  from  a server with binary logging enabled, xtrabackup will
791       create a file named xtrabackup_binlog_info  in  the  target  directory.
792       This  file  contains the binary log file name and position of the exact
793       point in the binary log to which the prepared backup corresponds.
794
795       You will also see output similar to the following  during  the  prepare
796       stage:
797
798          InnoDB: Last MySQL binlog file position 0 3252710, file name ./mysql-bin.000001
799          ... snip ...
800          [notice (again)]
801            If you use binary log and don't use any hack of group commit,
802            the binary log position seems to be:
803          InnoDB: Last MySQL binlog file position 0 3252710, file name ./mysql-bin.000001
804
805       This output can also be found in the xtrabackup_binlog_pos_innodb file,
806       but it is only correct when no other than XtraDB or InnoDB are used  as
807       storage engines.
808
809       If  other  storage  engines  are used (i.e. MyISAM), you should use the
810       xtrabackup_binlog_info file to retrieve the position.
811
812       The message about hacking group commit refers to an  early  implementa‐
813       tion of emulated group commit in Percona Server.
814
815   Point-In-Time Recovery
816       To  perform  a  point-in-time  recovery  from an xtrabackup backup, you
817       should prepare and restore the backup, and then replay binary logs from
818       the point shown in the xtrabackup_binlog_info file.
819
820       A more detailed procedure is found here (with innobackupex).
821
822   Setting Up a New Replication Slave
823       To  set up a new replica, you should prepare the backup, and restore it
824       to the data directory of your  new  replication  slave.  Then  in  your
825       CHANGE  MASTER  TO  command,  use  the binary log filename and position
826       shown in the xtrabackup_binlog_info file to start replication.
827
828       A more detailed procedure is  found  in   ../howtos/setting_up_replica‐
829       tion.
830
831   Restoring Individual Tables
832       In  server  versions  prior  to  5.6, it is not possible to copy tables
833       between servers by copying the files, even with  innodb_file_per_table.
834       However, with Percona XtraBackup, you can export individual tables from
835       any InnoDB database, and import them into Percona Server with XtraDB or
836       MySQL  5.6.  (The source doesn't have to be XtraDB or or MySQL 5.6, but
837       the destination does.) This only works on individual  .ibd  files,  and
838       cannot export a table that is not contained in its own .ibd file.
839
840       Let's see how to export and import the following table:
841
842          CREATE TABLE export_test (
843            a int(11) DEFAULT NULL
844          ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
845
846       NOTE:
847          If  you're  running  Percona  Server version older than 5.5.10-20.1,
848          variable   innodb_expand_import   should   be   used   instead    of
849          innodb_import_table_from_xtrabackup.
850
851   Exporting the Table
852       This  table  should have been created in innodb_file_per_table mode, so
853       after taking a backup as usual with  --backup,  the  .ibd  file  should
854       exist in the target directory:
855
856          $ find /data/backups/mysql/ -name export_test.*
857          /data/backups/mysql/test/export_test.ibd
858
859       when  you  prepare  the backup, add the extra parameter --export to the
860       command. Here is an example:
861
862          $ xtrabackup --prepare --export --target-dir=/data/backups/mysql/
863
864       Now you should see a .exp file in the target directory:
865
866          $ find /data/backups/mysql/ -name export_test.*
867          /data/backups/mysql/test/export_test.exp
868          /data/backups/mysql/test/export_test.ibd
869          /data/backups/mysql/test/export_test.cfg
870
871       These three files are all you need to import the table  into  a  server
872       running Percona Server with XtraDB or MySQL 5.6.
873
874       NOTE:
875          MySQL  uses  .cfg file which contains InnoDB dictionary dump in spe‐
876          cial format. This format is different from the .exp`  one  which  is
877          used in XtraDB for the same purpose. Strictly speaking, a .cfg` file
878          is not required to import a  tablespace  to  MySQL  5.6  or  Percona
879          Server 5.6. A tablespace will be imported successfully even if it is
880          from another server, but InnoDB will do  schema  validation  if  the
881          corresponding .cfg file is present in the same directory.
882
883   Importing the Table
884       On  the  destination  server  running  Percona  Server  with XtraDB and
885       innodb_import_table_from_xtrabackup option enabled, or MySQL 5.6,  cre‐
886       ate  a  table  with  the same structure, and then perform the following
887       steps:
888
889       · Execute ALTER TABLE test.export_test DISCARD TABLESPACE;
890
891         · If you see  the  following  message,  then  you  must  enable  inn‐
892           odb_file_per_table  and create the table again: ERROR 1030 (HY000):
893           Got error -1 from storage engine
894
895       · Copy the exported files to the test/ subdirectory of the  destination
896         server's data directory
897
898       · Execute ALTER TABLE test.export_test IMPORT TABLESPACE;
899
900       The table should now be imported, and you should be able to SELECT from
901       it and see the imported data.
902
903       NOTE:
904          Persistent statistics for imported tablespace will  be  empty  until
905          you  run the ANALYZE TABLE on the imported table. They will be empty
906          because they  are  stored  in  the  system  tables  mysql.innodb_ta‐
907          ble_stats  and  mysql.innodb_index_stats  and they aren't updated by
908          server during the import. This is due to upstream bug #72368.
909
910   LRU dump backup
911       This feature reduces the warm up time by restoring  buffer  pool  state
912       from  ib_lru_dump  file  after  restart.  Percona  XtraBackup discovers
913       ib_lru_dump and backs it up automatically.  [image]
914
915       If the buffer restore option is enabled in my.cnf buffer pool  will  be
916       in  the  warm  state  after  backup is restored. To enable this set the
917       variable innodb_buffer_pool_restore_at_startup =1 in Percona Server 5.5
918       or innodb_auto_lru_dump =1 in Percona Server 5.1.
919

IMPLEMENTATION

921   Implementation Details
922       This  page contains notes on various internal aspects of the xtrabackup
923       tool's operation.
924
925   File Permissions
926       xtrabackup opens the source data files in read-write mode, although  it
927       does not modify the files. This means that you must run xtrabackup as a
928       user who has permission to write the data files. The reason for opening
929       the  files in read-write mode is that xtrabackup uses the embedded Inn‐
930       oDB libraries to open and read the files,  and  InnoDB  opens  them  in
931       read-write  mode  because  it  normally assumes it is going to write to
932       them.
933
934   Tuning the OS Buffers
935       Because xtrabackup reads large amounts of data from the filesystem,  it
936       uses  posix_fadvise()  where possible, to instruct the operating system
937       not to try to cache the blocks it reads from disk. Without  this  hint,
938       the  operating  system  would prefer to cache the blocks, assuming that
939       xtrabackup is likely to need them again, which is not the case. Caching
940       such  large  files can place pressure on the operating system's virtual
941       memory and cause other processes, such as the database  server,  to  be
942       swapped out. The xtrabackup tool avoids this with the following hint on
943       both the source and destination files:
944
945          posix_fadvise(file, 0, 0, POSIX_FADV_DONTNEED)
946
947       In addition, xtrabackup asks  the  operating  system  to  perform  more
948       aggressive read-ahead optimizations on the source files:
949
950          posix_fadvise(file, 0, 0, POSIX_FADV_SEQUENTIAL)
951
952   Copying Data Files
953       When  copying  the data files to the target directory, xtrabackup reads
954       and writes 1MB of data at a time. This is not configurable. When  copy‐
955       ing the log file, xtrabackup reads and writes 512 bytes at a time. This
956       is also not possible to configure, and matches InnoDB's behavior (work‐
957       around  exists  in Percona Server because it has an option to tune inn‐
958       odb_log_block_size for XtraDB, and in that case Percona XtraBackup will
959       match the tuning).
960
961       After reading from the files, xtrabackup iterates over the 1MB buffer a
962       page at a time, and checks for page corruption on each page  with  Inn‐
963       oDB's  buf_page_is_corrupted()  function.  If  the  page is corrupt, it
964       re-reads and retries up to 10 times for each page. It skips this  check
965       on the doublewrite buffer.
966
967   xtrabackup Exit Codes
968       The  xtrabackup  binary  exits  with the traditional success value of 0
969       after a backup when no error occurs. If  an  error  occurs  during  the
970       backup, the exit value is 1.
971
972       In  certain  cases,  the exit value can be something other than 0 or 1,
973       due to the command-line option code included from the MySQL  libraries.
974       An unknown command-line option, for example, will cause an exit code of
975       255.
976

REFERENCES

978   The xtrabackup Option Reference
979       This page documents all of the command-line options for the  xtrabackup
980       binary.
981
982   Options
983       --apply-log-only
984              This option causes only the redo stage to be performed when pre‐
985              paring a backup. It is very important for incremental backups.
986
987       --backup
988              Make a backup and place  it  in  --target-dir.  See  Creating  a
989              backup.
990
991       --binlog-info
992              This  option  controls  how  Percona  XtraBackup should retrieve
993              server's binary log coordinates  corresponding  to  the  backup.
994              Possible  values are OFF, ON, LOCKLESS and AUTO. See the Percona
995              XtraBackup lockless_bin-log  manual page for more information
996
997       --close-files
998              Do not keep files opened. When xtrabackup  opens  tablespace  it
999              normally  doesn't  close  its file handle in order to handle the
1000              DDL operations correctly. However, if the number of  tablespaces
1001              is  really  huge  and  can  not  fit into any limit, there is an
1002              option to close file handles once they are no  longer  accessed.
1003              Percona  XtraBackup  can  produce inconsistent backups with this
1004              option enabled. Use at your own risk.
1005
1006       --compact
1007              Create a compact backup by skipping secondary index pages.
1008
1009       --compress
1010              This option  tells  xtrabackup  to  compress  all  output  data,
1011              including  the  transaction  log file and meta data files, using
1012              the specified compression algorithm.  The  only  currently  sup‐
1013              ported  algorithm  is  'quicklz'.  The  resulting files have the
1014              qpress archive format, i.e. every *.qp file  produced  by  xtra‐
1015              backup  is  essentially  a  one-file  qpress  archive and can be
1016              extracted and uncompressed by the qpress  file archiver.
1017
1018       --compress-chunk-size=#
1019              Size of working buffer(s) for compression threads in bytes.  The
1020              default value is 64K.
1021
1022       --compress-threads=#
1023              This option specifies the number of worker threads used by xtra‐
1024              backup for parallel data compression. This option defaults to 1.
1025              Parallel compression ('--compress-threads') can be used together
1026              with parallel file copying ('--parallel'). For example,  '--par‐
1027              allel=4   --compress  --compress-threads=2'  will  create  4  IO
1028              threads that will read the data and pipe  it  to  2  compression
1029              threads.
1030
1031       --create-ib-logfile
1032              This  option  is not currently implemented. To create the InnoDB
1033              log files, you must prepare the backup twice at present.
1034
1035       --datadir=DIRECTORY
1036              The source directory for the backup. This should be the same  as
1037              the  datadir  for  your  MySQL server, so it should be read from
1038              my.cnf if that exists; otherwise you must specify it on the com‐
1039              mand line.
1040
1041       --defaults-extra-file=[MY.CNF]
1042              Read this file after the global files are read. Must be given as
1043              the first option on the command-line.
1044
1045       --defaults-file=[MY.CNF]
1046              Only read default options from the given file. Must be given  as
1047              the  first  option  on the command-line. Must be a real file; it
1048              cannot be a symbolic link.
1049
1050       --defaults-group=GROUP-NAME
1051              This option is to set the group which should be  read  from  the
1052              configuration  file. This is used by innobackupex if you use the
1053              --defaults-group option. It is needed for  mysqld_multi  deploy‐
1054              ments.
1055
1056       --export
1057              Create files necessary for exporting tables. See Restoring Indi‐
1058              vidual Tables.
1059
1060       --extra-lsndir=DIRECTORY
1061              (for --backup): save an extra copy of the xtrabackup_checkpoints
1062              file in this directory.
1063
1064       --incremental-basedir=DIRECTORY
1065              When  creating an incremental backup, this is the directory con‐
1066              taining the full backup that is the base dataset for the  incre‐
1067              mental backups.
1068
1069       --incremental-dir=DIRECTORY
1070              When  preparing  an  incremental  backup,  this is the directory
1071              where the incremental backup is combined with the full backup to
1072              make a new full backup.
1073
1074       --incremental-force-scan
1075              When  creating  an  incremental backup, force a full scan of the
1076              data pages in the instance being backuped even if  the  complete
1077              changed page bitmap data is available.
1078
1079       --incremental-lsn=LSN
1080              When  creating  an  incremental  backup, you can specify the log
1081              sequence     number     (LSN)     instead     of      specifying
1082              --incremental-basedir.  For  databases created by MySQL and Per‐
1083              cona Server 5.0-series versions, specify the LSN as  two  32-bit
1084              integers  in  high:low  format. For databases created in 5.1 and
1085              later, specify the LSN as a  single  64-bit  integer.   ##ATTEN‐
1086              TION##:  If  a  wrong LSN value is specified (a user error which
1087              XtraBackup is unable to detect), the backup will be unusable. Be
1088              careful!
1089
1090       --innodb-log-arch-dir=DIRECTORY
1091              This  option  is  used  to  specify the directory containing the
1092              archived logs. It can only be used with the xtrabackup --prepare
1093              option.
1094
1095       --innodb-miscellaneous
1096              There  is a large group of InnoDB options that are normally read
1097              from the my.cnf configuration file, so that xtrabackup boots  up
1098              its  embedded  InnoDB  in the same configuration as your current
1099              server. You normally do not need to  specify  these  explicitly.
1100              These options have the same behavior that they have in InnoDB or
1101              XtraDB. They are as follows:
1102
1103                 --innodb-adaptive-hash-index
1104                 --innodb-additional-mem-pool-size
1105                 --innodb-autoextend-increment
1106                 --innodb-buffer-pool-size
1107                 --innodb-checksums
1108                 --innodb-data-file-path
1109                 --innodb-data-home-dir
1110                 --innodb-doublewrite-file
1111                 --innodb-doublewrite
1112                 --innodb-extra-undoslots
1113                 --innodb-fast-checksum
1114                 --innodb-file-io-threads
1115                 --innodb-file-per-table
1116                 --innodb-flush-log-at-trx-commit
1117                 --innodb-flush-method
1118                 --innodb-force-recovery
1119                 --innodb-io-capacity
1120                 --innodb-lock-wait-timeout
1121                 --innodb-log-buffer-size
1122                 --innodb-log-files-in-group
1123                 --innodb-log-file-size
1124                 --innodb-log-group-home-dir
1125                 --innodb-max-dirty-pages-pct
1126                 --innodb-open-files
1127                 --innodb-page-size
1128                 --innodb-read-io-threads
1129                 --innodb-write-io-threads
1130
1131       --log-copy-interval=#
1132              This option specifies time interval between checks done  by  log
1133              copying thread in milliseconds (default is 1 second).
1134
1135       --log-stream
1136              Makes xtrabackup not copy data files, and output the contents of
1137              the InnoDB log files to STDOUT until the  --suspend-at-end  file
1138              is deleted. This option enables --suspend-at-end automatically.
1139
1140       --no-defaults
1141              Don't  read  default options from any option file. Must be given
1142              as the first option on the command-line.
1143
1144       --databases=#
1145              This option specifies the list  of  databases  and  tables  that
1146              should  be  backed  up.  The option accepts the list of the form
1147              "databasename1[.table_name1] databasename2[.table_name2] . . .".
1148
1149       --databases-file=#
1150              This option specifies the path to the file containing  the  list
1151              of  databases  and tables that should be backed up. The file can
1152              contain  the  list  elements  of  the  form   databasename1[.ta‐
1153              ble_name1], one element per line.
1154
1155       --parallel=#
1156              This  option specifies the number of threads to use to copy mul‐
1157              tiple data  files  concurrently  when  creating  a  backup.  The
1158              default value is 1 (i.e., no concurrent transfer).
1159
1160       --prepare
1161              Makes  xtrabackup  perform  recovery  on  a  backup created with
1162              --backup, so that it is ready to use. See preparing a backup.
1163
1164       --print-defaults
1165              Print the program argument list and exit. Must be given  as  the
1166              first option on the command-line.
1167
1168       --print-param
1169              Makes xtrabackup print out parameters that can be used for copy‐
1170              ing the data files back to their original locations  to  restore
1171              them. See scripting-xtrabackup.
1172
1173       --rebuild_indexes
1174              Rebuild  secondary  indexes  in InnoDB tables after applying the
1175              log. Only has effect with --prepare.
1176
1177       --rebuild_threads=#
1178              Use this number of threads  to  rebuild  indexes  in  a  compact
1179              backup. Only has effect with --prepare and --rebuild-indexes.
1180
1181       --secure-auth
1182              Refuse  client  connecting  to server if it uses old (pre-4.1.1)
1183              protocol. (Enabled by default; use  --skip-secure-auth  to  dis‐
1184              able.)
1185
1186       --stats
1187              Causes xtrabackup to scan the specified data files and print out
1188              index statistics.
1189
1190       --stream=name
1191              Stream all backup files to the standard output in the  specified
1192              format. Currently supported formats are 'xbstream' and 'tar'.
1193
1194       --suspend-at-end
1195              Causes  xtrabackup  to create a file called xtrabackup_suspended
1196              in the --target-dir.  Instead  of  exiting  after  copying  data
1197              files,  xtrabackup  continues  to  copy  the log file, and waits
1198              until the xtrabackup_suspended file  is  deleted.  This  enables
1199              xtrabackup  and  other  programs  to  coordinate their work. See
1200              scripting-xtrabackup.
1201
1202       --tables=name
1203              A regular  expression  against  which  the  full  tablename,  in
1204              databasename.tablename  format, is matched. If the name matches,
1205              the table is backed up. See partial backups.
1206
1207       --tables-file=name
1208              A  file  containing  one  table  name  per  line,  in  database‐
1209              name.tablename  format. The backup will be limited to the speci‐
1210              fied tables. See scripting-xtrabackup.
1211
1212       --target-dir=DIRECTORY
1213              This option specifies the destination directory for the  backup.
1214              If  the  directory does not exist, xtrabackup creates it. If the
1215              directory does exist and  is  empty,  xtrabackup  will  succeed.
1216              xtrabackup  will  not overwrite existing files, however; it will
1217              fail with operating system error 17, file exists.
1218
1219              If this option is a relative path, it is  interpreted  as  being
1220              relative  to the current working directory from which xtrabackup
1221              is executed.
1222
1223       --throttle=#
1224              This  option  limits  --backup  to  the  specified   number   of
1225              read+write  pairs  of  operations  per  second. See throttling a
1226              backup.
1227
1228       --tmpdir=name
1229              This option is currently not used for anything  except  printing
1230              out the correct tmpdir parameter when --print-param is used.
1231
1232       --to-archived-lsn=LSN
1233              This  option is used to specify the LSN to which the logs should
1234              be applied when backups are being prepared. It can only be  used
1235              with the xtrabackup --prepare option.
1236
1237       --use-memory=#
1238              This option affects how much memory is allocated for preparing a
1239              backup with --prepare, or analyzing statistics with --stats. Its
1240              purpose  is  similar  to innodb_buffer_pool_size. It does not do
1241              the same thing as the similarly named option in Oracle's  InnoDB
1242              Hot  Backup  tool.  The  default value is 100MB, and if you have
1243              enough available memory, 1GB to 2GB is a good recommended value.
1244              Multiples  are  supported providing the unit (e.g. 1MB, 1M, 1GB,
1245              1G).
1246
1247       --version
1248              This option prints xtrabackup version and exits.
1249

AUTHOR

1251       Percona LLC and/or its affiliates
1252
1254       2009-2016, Percona LLC and/or its affiliates
1255
1256
1257
1258
12592.3.5                            Feb 13, 2019                    XTRABACKUP(1)
Impressum