数据库---------完全备份和增量备份的数据恢复,以及断点恢复

news2025/1/16 15:47:13

目录

一、在数据库表中,分三次录入学生考试成绩

1.1先创建库,创建表,完成三次数据的录入

1.2首次录入成绩后,做该表的完全备份

1.3第二次插入后 做增量备份

1.4第三次插入后 做增量备份

二、模拟数据丢失,并使用增量备份分别基于位置和时间点恢复一班所有学生成绩与二班陈铭与付杰的成绩

2.1用完全备份恢复,获取一班的人的成绩

2.2陈铭的成绩恢复

方法一:

方法二:

2.3付杰的成绩恢复

三、数据库上云迁移的方案?

1.1 方案一:使用脱机冷备份

1.2 方案二:热迁移

四、脚本增量备份

五、温故而知新


某学校进行期中考试要求录入各班考试成绩

为保证数据的可靠性录入学生成绩需要做数据库备份

为了测试备份数据是否可用,模拟数据丢失故障,进行数据还原需求描述

需求描述:

在数据库表中,分三次录入学生考试成绩

首次录入成绩后,做该表的完全备份,后两次成绩的录入之后,分别作增量备份

模拟数据丢失,并使用增量备份分别基于位置和时间点恢复一班所有学生成绩与二班陈铭与付杰的成绩

一、在数据库表中,分三次录入学生考试成绩

1.1先创建库,创建表,完成三次数据的录入

create table class(name varchar(10) unique key,class varchar(4),id int primary key,chinese int,math int,English int,sci int);

insert into class values('张三','一班',20170822,110,105,92,235);
insert into class values('李四','一班',20170820,95,115,110,260);
insert into class values('王五','一班',20170818,95,103,108,270);
insert into class values('赵六','一班',20170816,100,109,112,265);

1.2首次录入成绩后,做该表的完全备份

cd /opt
mkdir backup
mysqldump -uroot -p123123 nanjing class > /opt/backup/nanjing_class.sql
ls /opt/backup/
nanjing_class.sql

这是MySQL自带的备份和恢复工具支持逻辑热备份通过SQL语句的形式进行保存

[root@localhost opt]#cat /opt/backup/nanjing_class.sql
-- MySQL dump 10.13  Distrib 5.7.17, for Linux (x86_64)
--
-- Host: localhost    Database: nanjing
-- ------------------------------------------------------
-- Server version	5.7.17

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Table structure for table `class`
--

DROP TABLE IF EXISTS `class`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `class` (
  `name` varchar(10) DEFAULT NULL,
  `class` varchar(4) DEFAULT NULL,
  `id` int(11) NOT NULL,
  `chinese` int(11) DEFAULT NULL,
  `math` int(11) DEFAULT NULL,
  `English` int(11) DEFAULT NULL,
  `sci` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `class`
--

LOCK TABLES `class` WRITE;
/*!40000 ALTER TABLE `class` DISABLE KEYS */;
INSERT INTO `class` VALUES ('赵六','一班',20170816,100,109,112,265),('王五','一班',20170818,95,103,108,270),('李四','一班',20170820,95,115,110,260),('张三','一班',20170822,110,105,92,235);
/*!40000 ALTER TABLE `class` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

-- Dump completed on 2024-03-30 23:52:25

1.3第二次插入后 做增量备份

insert into class values('李宁','二班',20170824,92,98,105,235);
insert into class values('陈铭','二班',20170826,111,107,96,204);

开启二进制日志

log-error=/usr/local/mysql/data/mysql_error.log
general_log=ON
general_log_file=/usr/local/mysql/data/mysql_general.log
log-bin=mysql-bin
slow_query_log=ON
slow_query_log_file=/usr/local/mysql/data/mysql_slow_query.log
long_query_time=5
binlog_format = MIXED

mysqladmin -uroot -p123123 flush-logs
mv mysql-bin.000001 /opt/backup/mysql-bin.000001.$(date +%F_%T)
[root@localhost /opt/backup]#mysqlbinlog --no-defaults --base64-output=decode-rows -v 指定二进制日志备份文件

为什么空的?是由于没有在插入数据前,开启二进制日志,所以切记切记,一定要在开启二进制日志后,才可以插入数据,不然二进制日志识别不到哦

开启二进制日志后,先把之前错误的数据删除,然后我们在重复新插入数据

查看二进制日志

[root@localhost data]#mysqlbinlog --no-defaults --base64-output=decode-rows -v /usr/local/mysql/data/mysql-bin.000002 
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/;
/*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;
DELIMITER /*!*/;
# at 4
#240331 10:57:36 server id 1  end_log_pos 123 CRC32 0x68d67970 	Start: binlog v 4, server v 5.7.17-log created 240331 10:57:36
# Warning: this binlog is either in use or was not closed properly.
# at 123
#240331 10:57:36 server id 1  end_log_pos 154 CRC32 0x53f83afb 	Previous-GTIDs
# [empty]
# at 154
#240331 11:35:29 server id 1  end_log_pos 219 CRC32 0x8e1dc01f 	Anonymous_GTID	last_committed=0	sequence_number=1
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 219
#240331 11:35:29 server id 1  end_log_pos 304 CRC32 0xffd43c1e 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856129/*!*/;
SET @@session.pseudo_thread_id=4/*!*/;
SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/;
SET @@session.sql_mode=1437073414/*!*/;
SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/;
/*!\C utf8 *//*!*/;
SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=33/*!*/;
SET @@session.lc_time_names=0/*!*/;
SET @@session.collation_database=DEFAULT/*!*/;
BEGIN
/*!*/;
# at 304
#240331 11:35:29 server id 1  end_log_pos 421 CRC32 0x31a6b5eb 	Query	thread_id=4	exec_time=0	error_code=0
use `nanjing`/*!*/;
SET TIMESTAMP=1711856129/*!*/;
delete from class where name='李宁'
/*!*/;
# at 421
#240331 11:35:29 server id 1  end_log_pos 452 CRC32 0x57775191 	Xid = 8
COMMIT/*!*/;
# at 452
#240331 11:37:44 server id 1  end_log_pos 517 CRC32 0xb2bce275 	Anonymous_GTID	last_committed=1	sequence_number=2
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 517
#240331 11:37:44 server id 1  end_log_pos 602 CRC32 0x826c35bf 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856264/*!*/;
BEGIN
/*!*/;
# at 602
#240331 11:37:44 server id 1  end_log_pos 719 CRC32 0x4d30d3d9 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856264/*!*/;
delete from class where name='李宁'
/*!*/;
# at 719
#240331 11:37:44 server id 1  end_log_pos 805 CRC32 0x0effbaa6 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856264/*!*/;
COMMIT
/*!*/;
# at 805
#240331 11:38:09 server id 1  end_log_pos 870 CRC32 0x531b5239 	Anonymous_GTID	last_committed=2	sequence_number=3
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 870
#240331 11:38:09 server id 1  end_log_pos 955 CRC32 0x7e377af7 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856289/*!*/;
BEGIN
/*!*/;
# at 955
#240331 11:38:09 server id 1  end_log_pos 1072 CRC32 0x7f128ff4 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856289/*!*/;
delete from class where name='陈铭'
/*!*/;
# at 1072
#240331 11:38:09 server id 1  end_log_pos 1103 CRC32 0xe6e93731 	Xid = 10
COMMIT/*!*/;
# at 1103
#240331 11:38:34 server id 1  end_log_pos 1168 CRC32 0xd340a8d1 	Anonymous_GTID	last_committed=3    sequence_number=4
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 1168
#240331 11:38:34 server id 1  end_log_pos 1253 CRC32 0xb2d9ce6b 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856314/*!*/;
BEGIN
/*!*/;
# at 1253
#240331 11:38:34 server id 1  end_log_pos 1399 CRC32 0x62bc5441 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856314/*!*/;
insert into class values('李宁','二班',20170824,92,98,105,235)
/*!*/;
# at 1399
#240331 11:38:34 server id 1  end_log_pos 1430 CRC32 0xd85c6c10 	Xid = 12
COMMIT/*!*/;
# at 1430
#240331 11:38:39 server id 1  end_log_pos 1495 CRC32 0x0674a180 	Anonymous_GTID	last_committed=4    sequence_number=5
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 1495
#240331 11:38:39 server id 1  end_log_pos 1580 CRC32 0xed5f16ee 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856319/*!*/;
BEGIN
/*!*/;
# at 1580
#240331 11:38:39 server id 1  end_log_pos 1727 CRC32 0xd5dc66ea 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856319/*!*/;
insert into class values('陈铭','二班',20170826,111,107,96,204)
/*!*/;
# at 1727
#240331 11:38:39 server id 1  end_log_pos 1758 CRC32 0xd4119983 	Xid = 13
COMMIT/*!*/;
SET @@SESSION.GTID_NEXT= 'AUTOMATIC' /* added by mysqlbinlog */ /*!*/;
DELIMITER ;
# End of log file
/*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=0*/;

接下来开始做增量备份:

[root@localhost backup]#mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/backup/mysql-bin.000002.2024-03-31_11:58:58

[root@localhost backup]#mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/backup/mysql-bin.000002.2024-03-31_11:58:58
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/;
/*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;
DELIMITER /*!*/;
# at 4
#240331 10:57:36 server id 1  end_log_pos 123 CRC32 0x68d67970 	Start: binlog v 4, server v 5.7.17-log created 240331 10:57:36
# at 123
#240331 10:57:36 server id 1  end_log_pos 154 CRC32 0x53f83afb 	Previous-GTIDs
# [empty]
# at 154
#240331 11:35:29 server id 1  end_log_pos 219 CRC32 0x8e1dc01f 	Anonymous_GTID	last_committed=0	sequence_number=1
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 219
#240331 11:35:29 server id 1  end_log_pos 304 CRC32 0xffd43c1e 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856129/*!*/;
SET @@session.pseudo_thread_id=4/*!*/;
SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/;
SET @@session.sql_mode=1437073414/*!*/;
SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/;
/*!\C utf8 *//*!*/;
SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=33/*!*/;
SET @@session.lc_time_names=0/*!*/;
SET @@session.collation_database=DEFAULT/*!*/;
BEGIN
/*!*/;
# at 304
#240331 11:35:29 server id 1  end_log_pos 421 CRC32 0x31a6b5eb 	Query	thread_id=4	exec_time=0	error_code=0
use `nanjing`/*!*/;
SET TIMESTAMP=1711856129/*!*/;
delete from class where name='李宁'
/*!*/;
# at 421
#240331 11:35:29 server id 1  end_log_pos 452 CRC32 0x57775191 	Xid = 8
COMMIT/*!*/;
# at 452
#240331 11:37:44 server id 1  end_log_pos 517 CRC32 0xb2bce275 	Anonymous_GTID	last_committed=1	sequence_number=2
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 517
#240331 11:37:44 server id 1  end_log_pos 602 CRC32 0x826c35bf 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856264/*!*/;
BEGIN
/*!*/;
# at 602
#240331 11:37:44 server id 1  end_log_pos 719 CRC32 0x4d30d3d9 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856264/*!*/;
delete from class where name='李宁'
/*!*/;
# at 719
#240331 11:37:44 server id 1  end_log_pos 805 CRC32 0x0effbaa6 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856264/*!*/;
COMMIT
/*!*/;
# at 805
#240331 11:38:09 server id 1  end_log_pos 870 CRC32 0x531b5239 	Anonymous_GTID	last_committed=2	sequence_number=3
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 870
#240331 11:38:09 server id 1  end_log_pos 955 CRC32 0x7e377af7 	Query	thread_id=4	exec_time=0	error_code=0
SET TIMESTAMP=1711856289/*!*/;
BEGIN
/*!*/;
# at 955
#240331 11:38:09 server id 1  end_log_pos 1072 CRC32 0x7f128ff4 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856289/*!*/;
delete from class where name='陈铭'
/*!*/;
# at 1072
#240331 11:38:09 server id 1  end_log_pos 1103 CRC32 0xe6e93731 	Xid = 10
COMMIT/*!*/;
# at 1103
#240331 11:38:34 server id 1  end_log_pos 1168 CRC32 0xd340a8d1 	Anonymous_GTID	last_committed=3    sequence_number=4
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 1168
#240331 11:38:34 server id 1  end_log_pos 1253 CRC32 0xb2d9ce6b 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856314/*!*/;
BEGIN
/*!*/;
# at 1253
#240331 11:38:34 server id 1  end_log_pos 1399 CRC32 0x62bc5441 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856314/*!*/;
insert into class values('李宁','二班',20170824,92,98,105,235)
/*!*/;
# at 1399
#240331 11:38:34 server id 1  end_log_pos 1430 CRC32 0xd85c6c10 	Xid = 12
COMMIT/*!*/;
# at 1430
#240331 11:38:39 server id 1  end_log_pos 1495 CRC32 0x0674a180 	Anonymous_GTID	last_committed=4    sequence_number=5
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 1495
#240331 11:38:39 server id 1  end_log_pos 1580 CRC32 0xed5f16ee 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856319/*!*/;
BEGIN
/*!*/;
# at 1580
#240331 11:38:39 server id 1  end_log_pos 1727 CRC32 0xd5dc66ea 	Query	thread_id=4	exec_time=0 error_code=0
SET TIMESTAMP=1711856319/*!*/;
insert into class values('陈铭','二班',20170826,111,107,96,204)
/*!*/;
# at 1727
#240331 11:38:39 server id 1  end_log_pos 1758 CRC32 0xd4119983 	Xid = 13
COMMIT/*!*/;
# at 1758
#240331 11:58:28 server id 1  end_log_pos 1805 CRC32 0xb246b44f 	Rotate to mysql-bin.000003  pos: 4
SET @@SESSION.GTID_NEXT= 'AUTOMATIC' /* added by mysqlbinlog */ /*!*/;
DELIMITER ;
# End of log file
/*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=0*/;
[root@localhost backup]#

1.4第三次插入后 做增量备份

insert into class values('付杰','二班',20170828,115,118,116,268);
insert into class values('郭尚','二班',20170830,111,99,80,259);

二、模拟数据丢失,并使用增量备份分别基于位置和时间点恢复一班所有学生成绩与二班陈铭与付杰的成绩

模拟整个数据全部丢失,然后分析需要恢复一班的成绩那么就是将完全备份进行恢复,需要恢复陈铭和付杰的成绩,那么就是分别对第2和第3次的增量数据做断点恢复

2.1用完全备份恢复,获取一班的人的成绩

数据恢复:

mysql -uroot -p123123 nanjing < /opt/backup/nanjing_class.sql

注意路径哦

2.2陈铭的成绩恢复

mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/backup/mysql-bin.000002.2024-03-31_11:58:58

查看断点信息

方法一:

mysqlbinlog --no-defaults --start-position='1580' /opt/backup/mysql-bin.000002.2024-03-31_11:58:58|mysql -uroot -p123123

方法二:

mysqlbinlog --no-defaults --start-position='1580' --stop-position='1758' /opt/backup/mysql-bin.000002.2024-03-31_11:58:58|mysql -uroot -p123123

2.3付杰的成绩恢复

mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/backup/mysql-bin.000003.2024-03-31_12:13:22

数据恢复

mysqlbinlog --no-defaults --start-datetime='2024-03-31 12:07:14' --stop-datetime='2024-03-31 12:07:58' /opt/backup/mysql-bin.000003.2024-03-31_12:13:22|mysql -uroot -p123123

三、数据库上云迁移的方案?

1.1 方案一:使用脱机冷备份

冷迁移----物理冷备
首先需要关闭数据库服务;
然后用tar对数据库进行打包
再将tar包传给另一台主机
然后将其解压再恢复

1.2 方案二:热迁移

热迁移---阿里云自带的热迁移工具DTS(数据传输服务)

四、脚本增量备份

#!/bin/bash
##增量备份脚本
DIRLOGS=/var/log/mysql
LOGS_HOME=/usr/local/mysql/data
TODAY=$(data +%F)
YESTERDAY=$(date -d '-1 day' +%F)
USER=root
PASSWORD=abc123
 
#先判断收集备份文件的目录是否存在,不存在则创建目录
[ -d $DIRLOGS ]||mkdir -p $DIRLOGS
 
##备份二进制日志的索引文件到指定目录并加入时间标记
\cp  $LOGS_HOME/mysql_bin.index $DIRLOGS/mysql_bin.index.$TODAY
 
#先判断昨天的二进制日志的索引文件是否存在,存在则作为过滤条件过滤出今天需要备份的二进制日志文件名称
if [ -f $DIRLOGS/mysql_bin.index.$YESTERDAY ];then
    BINGLOG=$(cat $DIRLOGS/mysql_bin.index.$TODAY|grep -v $(cat $DIRLOGS/mysql_bin.index.$YESTERDAY)|awk -F/ '{print $2}')
  else
    BINGLOG=$(cat $DIRLOGS/mysql_bin.index.$TODAY|awk -F/ '{print $2}')
fi
 
##刷新生成新的二进制日志文件,便于收集最新的二进制日志
mysqladmin -u"$USER" -p"$PASSWORD" flush-logs &>/dev/null
 
##使用for循环,对所有的新产生的binlog文件进行备份
for i in $BINGLOG
do
mv $LOGS_HOME/$i  $DIRLOGS/$i.$TODAY
done

五、温故而知新

备份方法
物理备份:直接对数据库的物理文件(数据文件、日志文件等)进行备份
逻辑备份:对数据库的库和表对象以SQL语言的形式导出进行备份
 
备份策略
完全备份:每次备份都备份完整的库或者表数据
差异备份:只备份上一次完全备份后的更新数据
增量备份:每次备份只备份上一次完全备份或增量备份后的更新数据
 
 
数据库上云迁移     冷迁移     物理冷备      先关闭数据库,再打包备份+恢复
                   热迁移     阿里云 DTS
 
完全备份
物理冷备:先关闭数据库,使用tar命令打包备份数据库的数据目录和文件  mysql/data/
 
mysqldump逻辑热备
mysqldump -uXXX -pXXX  --databases 库1 [库2 ....] > XXX.sql       备份一个或多个库及库中所有的表数据
mysqldump -uXXX -pXXX  --all-databases > XXX.sql                  备份所有的库
mysqldump -uXXX -pXXX  库名 > XXX.sql                             备份指定库中的所有的表数据,不包含库对象
mysqldump -uXXX -pXXX  库名 表1 [表2 ....] > XXX.sql              备份指定库中的一个或多个表数据,不包含库对象
 
xtrabackup物理热备
 
 
完全恢复
先登录到数据库,再执行 source XXX.sql (如果sql文件是只备份了表数据的文件,需要先创建库并 use 切换库后再执行)
 
mysql -uXXX -pXXX < XXX.sql         cat XXX.sql | mysql -uXXX -pXXX                          恢复库
mysql -uXXX -pXXX 库名 < XXX.sql    cat XXX.sql | mysql -uXXX -pXXX 库名                     恢复表
 
 
增量备份
通过刷新二进制日志间接实现增量备份
mysqladmin -uXXX -pXXX flush-logs
 
查看二进制日志内容
mysqlbinlog --no-defaults --base64-output=decode-rows -v <BINLOG>
 
使用二进制日志增量恢复
mysqlbinlog --no-defaults <BINLOG> | mysql -uXXX -pXXX
 
断点恢复
基于位置点恢复
mysqlbinlog --no-defaults --start-position='开始位置点' --stop-position='结束位置点'  <BINLOG> | mysql -uXXX -pXXX
 
基于时间点恢复
mysqlbinlog --no-defaults --start-datetime='YYYY-mm-dd HH:MM:SS' --stop-position='YYYY-mm-dd HH:MM:SS'  <BINLOG> | mysql -uXXX -pXXX
 
如果需要恢复到某条sql语句之前的所有数据,就stop在这个语句的位置点或时间点之前
如果需要恢复某条sql语句及其之后的所有数据,就从这个语句的位置点或时间点开始start

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1560298.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

大文件上传做断点续传(有详细的代码内容)

文章目录 一、是什么分片上传断点续传 二、实现思路三、使用场景小结参考文献 一、是什么 不管怎样简单的需求&#xff0c;在量级达到一定层次时&#xff0c;都会变得异常复杂 文件上传简单&#xff0c;文件变大就复杂 上传大文件时&#xff0c;以下几个变量会影响我们的用户…

标题:Vue3 中父组件向子组件通信的方式

标题&#xff1a;Vue3 中父组件向子组件通信的方式 在 Vue3 中&#xff0c;父组件和子组件之间可以通过一些方式进行通信。其中&#xff0c;父组件向子组件通信主要有两种方式&#xff1a;传值和调用子组件的方法。 一、父组件向子组件传值 当父组件需要向子组件传递数据时&a…

快速排序---算法

1、算法概念 快速排序&#xff1a;通过一趟排序将待排记录分隔成独立的两部分&#xff0c;其中一部分记录的数据均比另一部分的数据小&#xff0c;则可分别对这两部分记录继续进行排序&#xff0c;以达到震哥哥序列有序。 快速排序的最坏运行情况是O()&#xff0c;比如说顺序数…

设计一个动物声音“模拟器”,希望模拟器可以模拟许多动物的叫声。

设计一个动物声音“模拟器”&#xff0c;希望模拟器可以模拟许多动物的叫声。要求如下&#xff1a; &#xff08;1&#xff09;编写接口Animal Animal接口有2个抽象方法cry()和getAnimaName()&#xff0c;即要求实现该接口的各种具体动物类给出自己的叫声和种类名称。 &…

设计模式 - 中介器模式

中介者模式使得组件通过一个中心点——中介者进行交互。组件不需要直接进行通信&#xff0c;而是将请求发送给中介者&#xff0c;由中介者进行转发&#xff01;在JavaScript中&#xff0c;中介者往往只是一个对象字面量或一个函数。 你可以将这种模式与空中交通管制员和飞行员…

科技革新,OTG充电新纪元!

在科技日新月异的今天&#xff0c;数据交互已经渗透到我们生活的每个角落&#xff0c;无论是工作还是娱乐&#xff0c;它都发挥着不可替代的作用。OTG技术的出现&#xff0c;极大地简化了设备间的联接与数据交换过程&#xff0c;但随之而来的接口有限和续航问题&#xff0c;也让…

产品经理的进阶之路

点击下载《产品经理的进阶之路》 1. 前言 本文深入剖析了产品经理这一职业从产品专员起步,逐步晋升为产品经理、高级产品经理,直至产品总监的整个职业发展路径。在每个阶段,产品经理都需承担不同的工作职责,展现出独特的职业特点。 2. 产品专员 关键词【产品需求/原型/文…

计算机服务器中了rmallox勒索病毒怎么办?rmallox勒索病毒解密数据恢复

网络技术的不断发展与应用&#xff0c;大大提高了企业的生产运营效率&#xff0c;越来越多的企业开始网络开展各项工作业务&#xff0c;网络在为人们提供便利的同时&#xff0c;也会存在潜在威胁。近日&#xff0c;云天数据恢复中心接到多家企业的求助&#xff0c;企业的计算机…

设计模式-概述篇

1. 掌握设计模式的层次 第1层&#xff1a;刚开始学编程不久&#xff0c;听说过什么是设计模式第2层&#xff1a;有很长时间的编程经验&#xff0c;自己写了很多代码&#xff0c;其中用到了设计模式&#xff0c;但是自己却不知道第3层&#xff1a;学习过了设计模式&#xff0c;…

Vue 3.0生命周期:深入理解与用法

Vue 3.0生命周期&#xff1a;深入理解与用法 摘要&#xff1a; 本文将深入探讨Vue 3.0的生命周期&#xff0c;解释每个生命周期钩子的含义和用法&#xff0c;以及它们在开发过程中的重要性。我们将详细解析每个钩子的工作原理&#xff0c;并提供一些示例和最佳实践&#xff0c…

python爬取B站视频

参考&#xff1a;https://cloud.tencent.com/developer/article/1768680 参考的代码有点问题&#xff0c;请求头需要修改&#xff0c;上代码&#xff1a; import requests import re # 正则表达式 import pprint import json from moviepy.editor import AudioFileClip, Vid…

常见贪心问题详解

目录 贪心算法应用条件 常见贪心问题 活动安排问题&#xff08;区间调度问题&#xff09; 区间覆盖问题 最优装载问题1 最优装载问题2 多机调度问题 例题&#xff1a;翻硬币 例题&#xff1a;快乐司机 例题&#xff1a;防御力 例题&#xff1a;答疑 贪心算法应用条件…

【通信原理笔记】【三】模拟信号调制——3.1 模拟信号调制基本模型与思路

文章目录 前言一、模拟信号二、模拟调制系统模型三、模拟调制的三种方式四、调制的评价指标总结 前言 一般常见的信号的频带均集中在基带附近&#xff0c;如果要通过无线地方式传输&#xff0c;其较长的波长需要大型的天线才能传输&#xff0c;难以实现。另一方面基带的带宽资…

ruoyi-nbcio-plus基于vue3的flowable执行监听器的升级修改

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 http://122.227.135.243:9666/ 更多nbcio-boot功能请看演示系统 gitee源代码地址 后端代码&#xff1a…

Linux基础命令篇之——压缩与解压(tar、gzip、bzip2、zip和unzip)

linux基础命令——解压与压缩 以下是关于Linux命令tar、gzip、bzip2、zip和unzip的详细介绍&#xff1a; 1. tar 这个是Linux用的最多的解压缩命令 tar是Linux系统中用于创建和处理归档文件的命令。归档文件是一个包含多个文件和/或目录的单一文件。常与压缩命令gzip或bzip2结…

图像处理_积分图

目录 1. 积分图算法介绍 2. 基本原理 2.1 构建积分图 2.2 使用积分图 3. 举个例子 1. 积分图算法介绍 积分图算法是图像处理中的经典算法之一&#xff0c;由Crow在1984年首次提出&#xff0c;它是为了在多尺度透视投影中提高渲染速度。 积分图算法是一种快速计算图像区域和…

wavedec2函数及使用

在MATLAB中&#xff0c;进行小波分解及其逆运算是处理图像的一种常见方法&#xff0c;尤其适用于图像分析、压缩和去噪等场景。wavedec2函数可以对二维信号&#xff08;例如图像&#xff09;进行多级小波分解&#xff0c;而waverec2函数则用于进行相应的逆运算。以下是如何使用…

非NVIDIA平台下的CUDA的替代方案OpenCL,第一步如何获取PlatformInfo、DeviceInfo

非NVIDIA平台下的CUDA的替代方案OpenCL&#xff0c;第一步如何获取PlatformInfo、DeviceInfo 介绍 当谈到高性能计算&#xff0c;NVIDIA的CUDA框架无疑是一个强大的工具。OpenC&#xff08;Open Computing Language&#xff09;是一个更为通用的解决方案&#xff0c;或者你使用…

java 跳转搜索(Jump Search)

与二分搜索一样&#xff0c;跳转搜索是一种针对排序数组的搜索算法。基本思想是通过按固定步骤向前跳跃或跳过某些元素来代替搜索所有元素来检查更少的元素&#xff08;比线性搜索&#xff09;。例如&#xff0c;假设我们有一个大小为 n 的数组 arr[] 和一个大小为 m 的块&…

隐私计算实训营学习六:隐语PIR介绍及开发指南

文章目录 一、隐语实现的PIR总体介绍1.1 PIR的定义和种类1.2 隐语PIR功能分层 二、Index PIR-SealPIR介绍三、Keyword PIR- Labeled PSI介绍四、隐语PIR后续计划 一、隐语实现的PIR总体介绍 1.1 PIR的定义和种类 PIR(Private Information Retrieval PIR)隐匿查询&#xff1a;…