赞
踩
物理备份又叫冷备份,需停止数据库服务,适合线下服务器
备份数据流程:
- 第一步:制作备份文件
- systemctl stop mysqld
- #创建存放备份文件的目录
- mkdir /bakdir
- #拷贝数据源文件
- cp -r /var/lib/mysql /bakdir/mysql.bak
- cd /var/lib/mysql
- #打包压缩数据源文件
- tar -zcvf /bakdir/mysql.tar.gz ./*
- 查看备份文件
- ls /bakdir
- mysql.bak mysql.tar.gz
- 看使用场景,习惯使用压缩包就使用mysql.tar.gz
-
-
- 第二步:删除原来的数据库数据
- rm -rf /var/lib/mysql/*
-
- 第三步:恢复数据
- 1.使用压缩包恢复数据
- #解压缩备份包
- tar -xf /bakdir/mysql.tar.gz -C /var/lib/mysql/
- #启动mysqld
- systemctl start mysqld
-
- mysql -uroot -p密码
- 回车
- mysql> show databases;
-
- 或者
-
- 2.使用cp拷贝的备份文件恢复数据
- systemctl stop mysqld
- rm -rf /var/lib/mysql/*
- cp -r /bakdir/mysql.bak/* /var/lib/mysql/
- chown -R mysql:mysql /var/lib/mysql
- #启动mysqld
- systemctl start mysqld
-
- mysql -uroot -p密码
- 回车
- mysql> show databases;
-

热备份,备份和恢复数据库服务必须是运行的
- // 备份1张表
- mysqldump -uroot -p密码 库 表 > /bakdir/db1_tb1.sql
- // 备份多张表
- mysqldump -uroot -p密码 库 表1 表2 表n > /bakdir/db1_tb1_tb2_tbn.sql
- // 备份多张表.sql
- // 备份一个库
- mysqldump -uroot -p密码 -B 表1 > /bakdir/tb1.sql
- // 备份多个库
- mysqldump -uroot -p密码 -B db1 db2 > /bakdir/db1_db2.sql
- // 备份所有库
- mysqldump -uroot -p密码 -A > /bakdir/allbak.sql
恢复数据(覆盖恢复数据)
- 第一种:恢复库数据步骤:
- 1. 删除库
- mysql -uroot -p密码 #登录
- mysql> drop database db1; //删除库
- mysql> exit
- 2. 命令行导入库数据
- mysql -uroot -p密码 < /bakdir/db1.sql //恢复数据
- 3. mysql登录验证
- mysql -uroot -p密码 #登录
- mysql> use db1; //进库
- mysql> show tables; //看表
-
- 第二种:恢复表数据步骤:
- 1. 删除表记录
- mysql> delete from tb1; //删除表记录
- mysql> exit
- 2. 命令行导入表文件
- mysql -uroot -p密码 db1 < /bakdir/db1_tb1.sql
- 3. mysql登录验证
- mysql -uroot -p密码 #登录
- mysql> select count(*) from db1.tb1; //查看行数

注意:mysqldump备份和恢复数据会锁表,锁表期间无法对表访问,mysqldump适合备份数据量比较小的数据或在数据库服务器访问量少的时候备份
增量备份:备份上次备份后,新产生的数据
xtrabackup是一款强大的在线热备份工具,备份过程中不锁库和表,适合生产环境.
支持完全备份与恢复,增量备份与恢复,差异备份与恢复.
准备2台虚拟机node1、node2
- //把软件拷贝到虚拟机里
- scp /percona-xtrabackup-8.0.26-18-Linux-x86_64.glibc2.12-minimal.tar.gz root@node1:/root/
- //安装依赖
- yum -y install perl-DBD-MySQL
- //解压源码
- tar -xf percona-xtrabackup-8.0.26-18-Linux-x86_64.glibc2.12-minimal.tar.gz
- //移动并改名
- mv percona-xtrabackup-8.0.26-18-Linux-x86_64.glibc2.12-minimal /usr/local/percona
- //把命令添加到系统环境变量
- vim /etc/bashrc
- export PATH=/usr/local/percona/bin:$PATH 添加在文件末尾
- :wq
- source /etc/bashrc
- //查看帮助信息
- man xtrabackup (按q 退出)
对数据做增量备份前,必须先有一次备份,也就是首次备份,通常是备份所有数据;
比如每周一完全备份,周二到周日增量备份.
周一完全备份(备份所有数据)
- xtrabackup \
- --host=127.0.0.1 \
- --user=root \
- --password=xxx \
- --backup \
- --target-dir=/fullbak \
- --datadir=/var/lib/mysql
-
-
- //插入新数据 (可以插入多行)
- mysql> insert into db1.tb1(date,employee_id,basic,bonus)values("20230610",18,25000,8000);
-
-
周二增量备份(备份周一备份后新产生的数据)
- xtrabackup \
- --host=127.0.0.1 \
- --user=root \
- --password=xxx \
- --backup \
- --target-dir=/new2 \
- --incremental-basedir=/fullbak \
- --datadir=/var/lib/mysql
-
-
- //插入新数据 (可以插入多行)
- mysql> insert into db1.tb1(date,employee_id,basic,bonus)values("20230610",18,25000,8000);
-
-
周三增量备份(备份周二备份后新产生的数据)
- xtrabackup \
- --host=127.0.0.1 \
- --user=root \
- --password=xxx \
- --backup \
- --target-dir=/new3 \
- --incremental-basedir=/new2 \
- --datadir=/var/lib/mysql
-
-
- //插入新数据 (可以插入多行)
- mysql> insert into db1.tb1(date,employee_id,basic,bonus)values("20230610",18,25000,8000);
-
-
以此类推到周日
前置准备工作:按照顺序将备份文件到目标主机的根目录下
- scp –r root@node1:/fullbak /
- scp –r root@node1:/new2 /
- scp –r root@node1:/new3 /
- scp –r root@node1:/new4 /
- scp –r root@node1:/new5 /
- scp –r root@node1:/new6 /
- scp –r root@node1:/new7 /
增量恢复数据步骤:
1.准备恢复数据
2.合并数据
3.清空数据库目录
4.拷贝数据
5.修改数据库目录所有者/组用户为mysql
6.重启数据库服务
7.连接数据库验证
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak \
- --incremental-dir=/new2
-
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak \
- --incremental-dir=/new3
-
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak \
- --incremental-dir=/new4
-
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak \
- --incremental-dir=/new5
-
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak \
- --incremental-dir=/new6
-
- xtrabackup \
- --prepare \
- --apply-log-only \
- --target-dir=/fullbak \
- --incremental-dir=/new7

rm -rf /var/lib/mysql/*
xtrabackup --copy-back --target-dir=/fullbak
chown -R mysql:mysql /var/lib/mysql
systemctl restart mysqld
- mysql -uroot -p密码
- mysql> select count(*) from tarena.salary
对数据做差异备份前,必须先有一次备份,也就是首次备份,通常啥备份所有数据
比如每周一完全备份,周二到周日差异备份
3.1周一完全备份
- xtrabackup --host=127.0.0.1 \
- --user=root \
- --password=123456 \
- --backup \
- --target-dir=/allbak \
- --datadir=/var/lib/mysql
增加表格数据的操作就不赘述了
周二差异备份(备份周一备份后新产生的数据)
- xtrabackup --host=127.0.0.1 \
- --user=root \
- --password=123456 \
- --backup \
- --target-dir=/dir2 \
- --incremental-basedir=/allbak \
- --datadir=/var/lib/mysql
周三差异备份(备份周一备份后新产生的数据)
- xtrabackup --host=127.0.0.1 \
- --user=root \
- --password=123456 \
- --backup \
- --target-dir=/dir3 \
- --incremental-basedir=/allbak \
- --datadir=/var/lib/mysql
因为都是备份的周一备份后新产生的数据,所以实际上只需要在上述命令基础上修改--target-dir=当日备份目录路径
直接推断到周日差异备份(备份周一备份后新产生的数据)
- xtrabackup --host=127.0.0.1 \
- --user=root \
- --password=123456 \
- --backup \
- --target-dir=/dir7 \
- --incremental-basedir=/allbak \
- --datadir=/var/lib/mysql
差异恢复数据步骤:
前置准备工作:远程拷贝备份数据到目标主机的根目录
- scp –r root@node1:/allbak /
- scp –r root@node1:/dir7 /
- xtrabackup --prepare \
- --apply-log-only \
- --target-dir=/allbak
- xtrackup --prepare \
- --apply-log-only \
- --target-dir=/allbak \
- --incremental-dir=/dir7
rm -rf /var/lib/mysql/*
xtrabackup --copy-back --target-dir=/allbak
chown -R mysql:mysql /var/lib/mysql
systemctl restart mysqld
binlog日志介绍:
1.也称为二进制日志
2.mysql服务日志文件的一种
3.保存除查询之外的所有sql命令
4.可用于数据的备份和恢复
5.配置mysql主从同步的必要条件
注:日志文件默认保存在/var/lib/mysql目录下,默认日志名binlog,如果在/etc/my.cnf.d/mysql-server.cnf修改过bin-log的配置应按照配置文件查找
假设bin-log的配置改为/mylog/node1
- mysql> show master status;
-
- +----------------+----------+--------------+------------------+-------------------+
- | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
- +----------------+----------+--------------+------------------+-------------------+
- | node1.000001 | 156 | | | |
- +----------------+----------+--------------+------------------+-------------------+
exit退出mysql
mysql> exit
在linux系统命令行将日志文件远程拷贝到目标主机
scp /mylog/node1.000001 root@node2:/root/
ls /root/node1.000001
恢复数据命令:
mysqlbinlog /目录/文件名 | mysql -uroot -p密码
结合实际应为:
mysqlbinlog /root/node1.000001 | mysql -uroot -p密码
在Linux环境下,MySQL数据库的备份可以通过以下方式进行:
完整备份(Full Backup):备份整个数据库。
差异备份(Differential Backup):仅备份上次完整备份后发生变化的数据。
增量备份(Incremental Backup):仅备份自上次增量备份以来发生变化的数据。
binlog备份:备份MySQL的二进制日志文件(binlog),记录了所有数据库更改的历史。
优缺点对比:
备份名称 | 优点 | 缺点 |
完整备份 | 简单 | 1.数据冗余 2.备份时间长 |
差异备份 | 备份数据量小 | 恢复时需要先恢复完整备份 |
增量备份 | 1.备份数据量小 2.恢复数据快 | 需要上次的完整备份或差异备份 |
binlog备份 | 1.能够精确到行级别 2.恢复速度快 | 需要mysql的二进制更能开启 |
实际选择哪种备份策略取决于数据的重要性、恢复需求和备份策略的实施复杂度。
systemctl stop redis
rm -rf /var/lib/redis/*
设置存盘间隔为120秒且10个key,改变数据自动存盘设置:存盘间隔120秒且10个key改变,则数据自动存盘
- vim /etc/redis.conf
- save 900 1
- #save 300 10
- save 120 10 # 2分钟内且有>=10个变量改变,就把内存里的数据复制到dump.rdb文件里
- save 60 10000
systemctl start redis
- #查看dump.rdb
- ls /var/lib/redis/dump.rdb
- 提示没有该文件或目录就行
要在2分钟内存储大于等于10个变量
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> mset a 1 b 2 c 3 d 4
- OK
- 192.168.88.70:6379> mset ... (像上面那个例子一样添加数据,凑足至少10个变量的改动...)
- 192.168.88.70:6379> exit
- #redis赋值后查看是否有dump.rdb文件
- ls /var/lib/redis/ -l
- cp /var/lib/redis/dump.rdb /opt/
-
- #查看是否拷贝成功
- ls /opt/*.rdb
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> FLUSHALL
- 192.168.88.70:6379> keys *
- 192.168.88.70:6379> exit
systemctl stop redis
rm -rf /var/lib/redis/*
cp /opt/dump.rdb /var/lib/redis/
systemctl start redis
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> keys *
config set appendonly yes #启用aof文件
config rewrite #保存配置
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> config set appendonly yes #启用aof文件
- 192.168.88.70:6379> config get appendonly #查看是否启用
- 192.168.88.70:6379> config rewrite #保存配置
- 192.168.88.70:6379> exit
-
- #查看数据库目录是否有.aof文件
- ls /var/lib/redis
- #查看文件行数
- wc -l /var/lib/redis/appendonly.aof
-
-
- 测试增加数据,行数是否变化:
- #进入redis命令行,添加存储数据
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> 使用set或者mset增加存储变量
- 192.168.88.70:6379> keys * #查看变量
- 192.168.88.70:6379> exit
-
- #查看文件函数
- wc -l /var/lib/redis/appendonly.aof

- 第一步.备份aof文件
- cp /var/lib/redis/appendonly.aof /opt/
- #查看是否备份成功
- ls /opt/*.aof
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> flushall
- 192.168.88.70:6379> exit
systemctl stop redis
为了不影响备份效果,删除/var/lib/redis/下的aof文件或者rdb文件
rm -rf /var/lib/redis/*
- cp /opt/appendonly.aof /var/lib/redis/
-
- ll /var/lib/redis/ #查看文件的主和组是不是都是redis
- #如果不是,需要修改为redis的主和组:
- chown -R redis:redis /var/lib/redis/
systemctl start redis
- redis-cli -h 192.168.88.70 -p 6379
- 192.168.88.70:6379> keys *
如果redis-cli命令连接命令行失败,先查看appendonly文件的owner和group是不是redis,不是redis的使用chown改成redis的主和组,然后再尝试连接redis命令行,如下图所示:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。