【网络拓扑图】
【实验环境描述】
某学校近期在进行其中考试,要求数据库管理员负责一班、二班学生的考试成绩录入,为保证数据的可靠性,数据库管理员在录入学生成绩后均要做数据库备份,并且为了测试备份数据是否可用,模拟数据丢失故障,进行数据还原。
【推荐步骤】
创建数据库与表
分三次录入学生成绩,并在分别进行完全备份与增量备份
模拟数据丢失,进行数据恢复
【需求描述】
在数据库表中,分三次录入徐文胜考试成绩,具体的考试成绩信息分别参见表
一班学生成绩
姓名 班级 学号 语文 数学 英语 理综
张三 一班 20170822 110 105 92 235
李四 一班 20170820 95 115 110 260
王五 一班 20170818 95 103 108 270
赵六 一班 20170816 100 109 112 265
二班学生成绩(1)
姓名 班级 学号 语文 数学 英语 理综
李宁 二班 20170824 92 98 105 235
陈铭 二班 20170826 111 107 96 204
二班学生成绩(2)
姓名 班级 学号 语文 数学 英语 理综
付杰 二班 20170828 115 118 116 268
郭尚 二班 20170830 111 99 80 259
首次录入成绩后,做该表的完全备份,后两次成绩的录入之后,分别做增量备份
模拟数据丢失,并使用增量备份分别基于位置和时间点恢复一班所有学生成绩与二班陈铭与付杰的成绩
1.创建数据库
mysql> create database bdqn;
2.创建表
mysql> create table bdqn.1ban(名字 char(5),班级 char(2),学号 char(8),语文 char(3),数学 char(3),英语 char(3),理综 char(3));
3.插入一班数据
4.配置日志分割
root@centos01 ~]# mysqladmin -uroot -ppwd@123 flush-log
5.查看二进制日志
[root@centos01 data]# mysqlbinlog /usr/local/mysql/data/mysql-bin.000003
6.加入二班数据
7.配置日志分割,查看
root@centos01 ~]# mysqladmin -uroot -ppwd@123 flush-log
8.加入三班数据并切割
9.模拟数据损坏
.10.以位置恢复
mysqlbinlog–start-position=’347’./mysql-bin.000009–stop-position=’783’ mysql-bin.0000009 | mysql -urrot -ppwd@123
11以时间做备份
mysqlbinlog–start-datetume=’2020-11-3017:23:25’./mysql-bin.0000010–stop-datetime=’2020-11-30’ 17:24:14’ mysql-bin.00000010 | mysql -urrot -ppwd@123