Skip to content

Encrypt backups

Percona XtraBackup supports encrypting and decrypting local and streaming backups with the upstream option, adding another protection layer. The encryption is implemented using the libgcrypt library from GnuPG.

Create encrypted backups

The following options create encrypted backups. The --encrypt-key and --encrypt-key-file options specify the encryption key and are mutually exclusive. You should select one or the other.

  • --encrypt

  • --encrypt-key

  • --encrypt-key-file

For an encryption key, use a command, such as openssl rand -base64 24, to generate a random alphanumeric string.

The --encrypt-key option

An example of the xtrabackup command using the --encrypt-key:

$  xtrabackup --backup --encrypt=AES256 --encrypt-key="{randomly-generated-alphanumeric-string}" --target-dir=/data/backup

The --encrypt-key-file option

The recommended method uses the command line: echo -n “{randomly-generated-alphanumeric-string}” > /data/backups/keyfile to create the file.

Remember that your text editor can automatically insert a CRLF (end of line) character in the KEYFILE when using the– encrypt-key-file option. This inserted character invalidates the key because the size is wrong.

An example of using the --encrypt-key-file option:

$ xtrabackup --backup --encrypt=AES256 --encrypt-key-file=/data/backups/keyfile --target-dir=/data/backup

Optimize the encryption process

Additional encrypted backup options, --encrypt-threads and --encrypt-chunk-size, can speed up the encryption process.

Use the --encrypt-threads option to enable parallel encryption with multiple threads.

The --encrypt-chunk-size option specifies the size, in bytes, of the working encryption buffer for each encryption thread. The default size is 64K.

Decrypt encrypted backups

You can decrypt backups with the xbcrypt binary. The following example encrypts a backup.

You can use the --parallel option and the --decrypt option to decrypt multiple files simultaneously.

$ for i in `find . -iname "*\.xbcrypt"`; do xbcrypt -d --encrypt-key-file=/root/secret_key --encrypt-algo=AES256 < $i > $(dirname $i)/$(basename $i .xbcrypt) && rm $i; done

The following example shows a decryption process.

$ xtrabackup --decrypt=AES256 --encrypt-key="{randomly-generated-alphanumeric-string}" --target-dir=/data/backup/

Percona XtraBackup doesn’t automatically remove the encrypted files. You must remove the \*.xbcrypt files manually.

Prepare encrypted backups

After decrypting the backups, prepare the backups with the --prepare option:

$ xtrabackup --prepare --target-dir=/data/backup/

Restore encrypted backups

xtrabackup offers the --copy-back option to restore a backup to the server’s datadir:

$ xtrabackup --copy-back --target-dir=/data/backup/

The option copies all the data-related files to the server’s datadir. The server’s my.cnf configuration file determines the location.

You should check the last line of the output for a success message:

Expected output
150318 11:08:13  xtrabackup: completed OK!

Last update: 2024-01-03