innobackupex备份恢复,全备,增备,恢复单库单表

innobackupex备份恢复,全备,增备,恢复单库单表
摘要由CSDN通过智能技术生成

一、全备

-- 删除8天前备份

-- find /data/mysqldata/back_dir/ -maxdepth 1 -mtime +8 -type d -exec rm -rf {} \;

/usr/bin/innobackupex  --defaults-file=/etc/my.cnf  --user=root  --password=密码 --no-lock  /data/mysqldata/back_dir/

全备恢复整库则直接使用全备文件夹即可;

全备恢复单库、单表

将备份文件复制到20220809文件夹

cp backup-my.cnf ib_buffer_pool ibdata1 ib_logfile0 ib_logfile1 ibtmp1 xtrabackup_binlog_info xtrabackup_binlog_pos_innodb xtrabackup_checkpoints xtrabackup_info xtrabackup_logfile xtrabackup_master_key_id /data/mysqldata2/20220809/

cp -r mysql performance_schema 数据库 /data/mysqldata2/20220809/


删除ib_logfile0 ib_logfile01
/data/mysqldata/log/relay_log/ib_logfile0
rm -rf ib_logfile0 ib_logfile1

 应用redo日志
innobackupex --defaults-file=/etc/my.cnf --apply-log /data/mysqldata2/20220809/

复制文件
innobackupex --defaults-file=/etc/my.cnf --copy-back /data/mysqldata2/20220809/

chown -R mysql:mysql /data/mysqlnew
chown mysql:mysql ib_logfile0 ib_logfile1

删除ib_logfile0 ib_logfile01
/data/mysqldata/log/relay_log/ib_logfile0
rm -rf ib_logfile0 ib_logfile1


systemctl start mysqld.service

二、增备:

先进行全备

/usr/bin/innobackupex  --defaults-file=/etc/my.cnf  --user=root  --password=密码 --no-lock  /data/mysqldata/back_dir/

增备

/usr/bin/innobackupex  --defaults-file=/etc/my.cnf  --user=root  --password=密码 --no-lock  --incremental /data/mysqldata/back_inc_dir/ --incremental-basedir=$FULLBACKUP

其中$FULLBACKUP= /data/mysqldata/back_dir/时间戳

$INCREMENTALBACKUP= /data/mysqldata/back_inc_dir/ 时间戳

恢复全备

innobackupex --defaults-file=/etc/my.cnf --apply-log --redo-only $FULLBACKUP

增备应用于全备

innobackupex --defaults-file=/etc/my.cnf --apply-log --redo-only $FULLBACKUP --incremental-dir=$INCREMENTALBACKUP

将所有部分放在一起后,再次准备完整备份(基本 + 增量)以回滚待处理的事务:

innobackupex --defaults-file=/etc/my.cnf --apply-log $FULLBACKUP

剩余步骤和全备恢复相同

-------------------------------------------------------------------------------------------------------------------------------

#!/bin/bash

mysqldump -u root -p --single-transaction --set-gtid-purged=OFF  --databases test --tables  test> /data/back_dir/`date +%Y%m%d%H%M`.sql
find /data/back_dir/ -mtime +5 -name "*.sql" -exec rm -rf {} \;

crontab -e

10 5 * * * sh /data/back_dir/test.sh

```````

mysqldump 参数

--host=host_name, -h host_name
MySQL 数据库主机地址,默认为 localhost。
示例:mysqldump -uroot -p --host=localhost --all-databases

--port=port_num, -P port_num
连接数据库端口号

--user=user_name, -u user_name
指定连接数据库的用户名。

--password[=password], -p[password]
连接数据库的密码

--all-databases, -A
导出全部数据库的全部表。示例:mysqldump -uroot -p --all-databases

--databases,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LOST_9

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值