MySQL的备份与还原,非常规备份,全量备份,增量备份
wptr33 2025-05-03 16:58 26 浏览
一、测试数据库的创建
1:官方百万级别的测试数据库:
官方测试数据库github网址:
https://github.com/datacharmer/test_db
下载到目录,解压即可,运行命令:
mysql -u root -p < employees.sql
mysql -u root -p < employees_partitioned.sql2:自己创建简单测试数据库:
快速随机生成测试语言的网站:https://generatedata.com/
选择sql和想生成的字段,点击生成Generate!生成即可。
在MySQL输入生成的语句即可。
#1:创建数据库
create database testDatabase;
#2:使用数据库
use testDatabase;
#3:创建表
CREATE TABLE `myTable` (
`id` mediumint(8) unsigned NOT NULL auto_increment,
`name` varchar(255) default NULL,
`phone` varchar(100) default NULL,
`country` varchar(100) default NULL,
`numberrange` mediumint default NULL,
PRIMARY KEY (`id`)
) AUTO_INCREMENT=1;
#3:表种插入数据
INSERT INTO `myTable` (`name`,`phone`,`country`,`numberrange`)
VALUES
("Wade Sykes","1-917-342-3132","Turkey",3),
("Barrett Boyer","1-264-304-0665","Germany",9),
("Alana Kaufman","(213) 254-4997","India",0),
("Emmanuel Lopez","(543) 493-0137","Germany",9),
("Timon Bauer","1-269-448-2772","Pakistan",6);3:测试备份还原时用到的命令
删库跑路测试(先备份好)
drop database testDatabase;还原后查询库的表数据是否完整。
select * from testDatabase.myTable
+----+----------------+----------------+----------+-------------+
| id | name | phone | country | numberrange |
+----+----------------+----------------+----------+-------------+
| 1 | Wade Sykes | 1-917-342-3132 | Turkey | 3 |
| 2 | Barrett Boyer | 1-264-304-0665 | Germany | 9 |
| 3 | Alana Kaufman | (213) 254-4997 | India | 0 |
| 4 | Emmanuel Lopez | (543) 493-0137 | Germany | 9 |
| 5 | Timon Bauer | 1-269-448-2772 | Pakistan | 6 |
+----+----------------+----------------+----------+-------------+二、非常规备份方式
采用复制整个数据存放目录
1:查看数据库数据存放位置
有两种方法:
1):在数据库中用命令 show variables like 'datadir'; 查看
mysql > show variables like 'datadir';
+---------------+-----------------+
| Variable_name | Value |
+---------------+-----------------+
| datadir | /var/lib/mysql/ |
+---------------+-----------------+
1 row in set
Time: 0.031s2):在配置文件中查看,配置了 datadir 目录的可查看。没有配置的默认为 /var/lib/mysql/ 位置
Linux中查看配置文件
#centos
cat /etc/my.cnf
#ubunut
cat /etc/mysql/my.cnf2:复制目录或者目录下某个数据库名
cp -fr /var/lib/mysql/ /backup/3:还原时直接复制文件夹到数据库目录即可
cp -fr /backup/ /var/lib/mysql/三、常规备份方式基本命令mysqldump
mysqldump又可叫做全量备份。
参数 --databases 同 -B ,单独一个库,也可省略。
1、备份命令mysqldump格式
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 database 数据库名 > 文件名.sql
备份testDatabase数据库
sudo mysqldump -u root -p --databases testDatabase > testdatabase.bak.sql2、备份MySQL数据库为带删除表的格式
备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
sudo mysqldump --add-drop-table -u root -p --databases testDatabase > testdatabase.sql3、直接将MySQL数据库压缩备份
备份并压缩
sudo mysqldump -u root -p --databases testDatabase | gzip > testdatabase.sql.gz4、备份MySQL数据库某个(些)表
备份testDatabase中的myTable表,不需要用参数 --databases 或者 -B
sudo mysqldump -u root -p testDatabase myTable > myTable.sql5、同时备份多个MySQL数据库
同时备份testDatabase和 employees两个库
sudo mysqldump -u root --databases testDatabase employees > backup.sql6、备份服务器上所有数据库
参数 --all-databases 同 -A
sudo mysqldump --all-databases > allbackupfile.sql7、还原MySQL数据库的命令
1) 不指定数据名还原,默认生成原数据库名称,还原所有数据库。
sudo mysql -u root -p < allbackupfile.sql2) 指定数据名还原,还原指定单个数据库,需在数据库种预先创建一个testDatabase名称。
sudo mysql -u root -p testDatabase < allbackupfile.sql3) 还原压缩的MySQL数据库
gunzip < testDatabase.sql.gz | mysql -u root -p testDatabase
#ubuntu 加sudo
sudo gunzip < testDatabase.sql.gz | sudo mysql -u root -p testDatabase4) 进入数据库用source导入
#进入MySQL后,先创建database:
CREATE DATABASE testDatabase;
#选择数据库
USE testDatabase;
#导入sql文件
SOURCE /home/ubuntu/testDatabase.sql;四、增量备份mysqladmin,以及还原
增量备份是针对于数据库的bin-log日志进行备份的,增量备份是在全量的基础上进行操作的。增量备份主要是靠mysql记录的bin-log日志。
1:查看是否开启bin-log日志
进入mysql输入命令可查看。
show variables like '%log_bin%';显示如下为开启状态,日志文件在/var/lib/mysql/以binlog.00001的格式保存。
mysql> show variables like '%log_bin%';
+---------------------------------+-----------------------------+
| Variable_name | Value |
+---------------------------------+-----------------------------+
| log_bin | ON |
| log_bin_basename | /var/lib/mysql/binlog |
| log_bin_index | /var/lib/mysql/binlog.index |
| log_bin_trust_function_creators | OFF |
| log_bin_use_v1_row_events | OFF |
| sql_log_bin | ON |
+---------------------------------+-----------------------------+
6 rows in set
Time: 0.012s
mysql root@(none):testDatabase> 如未开启,需要在配置文件种配置
[mysqld]
#binlog setting,开启增量备份的关键
log-bin=/var/lib/mysql/binlog2:查看目前使用的bin-log日志文件
进入mysql查看命令。
show master status;显示如下,目前使用的是binlog.000022文件,所有操作都记录在此文件。
mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000022 | 156 | | | |
+---------------+----------+--------------+------------------+-------------------+
1 row in set
Time: 0.007s查看当前testDatabase的表myTable数据如下,
mysql > select * from testDatabase.myTable
+----+----------------+----------------+----------+-------------+
| id | name | phone | country | numberrange |
+----+----------------+----------------+----------+-------------+
| 1 | Wade Sykes | 1-917-342-3132 | Turkey | 3 |
| 2 | Barrett Boyer | 1-264-304-0665 | Germany | 9 |
| 3 | Alana Kaufman | (213) 254-4997 | India | 0 |
| 4 | Emmanuel Lopez | (543) 493-0137 | Germany | 9 |
| 5 | Timon Bauer | 1-269-448-2772 | Pakistan | 6 |
| 7 | ABC | 1-917-342-3123 | KHMER | 6 |
+----+----------------+----------------+----------+-------------+
6 rows in set
Time: 0.008s3:刷新日志,使用新的日志文件(备份)
在命令端执行命令
mysqladmin -u root -p flush-logs日志文件从 binlog.000022 变为 binlog.000023
mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000023 | 841 | | | |
+---------------+----------+--------------+------------------+-------------------+
1 row in set
Time: 0.007s这时相当与已经备份成功,备份文件即为上次的binlog.000022日志文件。
4:删除数量,从日志还原数据
1) 删除ABC行
delete from `myTable` where name = 'ABC';查询以及没有ABC行列。
mysql> select * from testDatabase.myTable
+----+----------------+----------------+----------+-------------+
| id | name | phone | country | numberrange |
+----+----------------+----------------+----------+-------------+
| 1 | Wade Sykes | 1-917-342-3132 | Turkey | 3 |
| 2 | Barrett Boyer | 1-264-304-0665 | Germany | 9 |
| 3 | Alana Kaufman | (213) 254-4997 | India | 0 |
| 4 | Emmanuel Lopez | (543) 493-0137 | Germany | 9 |
| 5 | Timon Bauer | 1-269-448-2772 | Pakistan | 6 |
+----+----------------+----------------+----------+-------------+
5 rows in set
Time: 0.008s2) 恢复数据ABC行
退出mysql,在命令端用mysqlbinlog命令恢复到binlog.000022日志状态。
sudo mysqlbinlog /var/lib/mysql/binlog.000022 | sudo mysql -u root -p testDatabase;进入数据库再次查看数据,ABC已经恢复。
mysql> select * from testDatabase.myTable
+----+----------------+----------------+----------+-------------+
| id | name | phone | country | numberrange |
+----+----------------+----------------+----------+-------------+
| 1 | Wade Sykes | 1-917-342-3132 | Turkey | 3 |
| 2 | Barrett Boyer | 1-264-304-0665 | Germany | 9 |
| 3 | Alana Kaufman | (213) 254-4997 | India | 0 |
| 4 | Emmanuel Lopez | (543) 493-0137 | Germany | 9 |
| 5 | Timon Bauer | 1-269-448-2772 | Pakistan | 6 |
| 7 | ABC | 1-917-342-3123 | KHMER | 6 |
+----+----------------+----------------+----------+-------------+
6 rows in set
Time: 0.008s增量备份完成。
相关推荐
- oracle数据导入导出_oracle数据导入导出工具
-
关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...
- 继续学习Python中的while true/break语句
-
上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...
- python continue和break的区别_python中break语句和continue语句的区别
-
python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...
- 简单学Python——关键字6——break和continue
-
Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
-
用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...
- Python 中 break 和 continue 傻傻分不清
-
大家好啊,我是大田。...
- python中的流程控制语句:continue、break 和 return使用方法
-
Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...
- L017:continue和break - 教程文案
-
continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...
- 作为前端开发者,你都经历过怎样的面试?
-
已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...
- 面试被问 const 是否不可变?这样回答才显功底
-
作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...
- 2023金九银十必看前端面试题!2w字精品!
-
导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...
- 前端面试总结_前端面试题整理
-
记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...
- 由浅入深,66条JavaScript面试知识点(七)
-
作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...
- 2024前端面试真题之—VUE篇_前端面试题vue2020及答案
-
添加图片注释,不超过140字(可选)...
- 今年最常见的前端面试题,你会做几道?
-
在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...
- 一周热门
- 最近发表
-
- oracle数据导入导出_oracle数据导入导出工具
- 继续学习Python中的while true/break语句
- python continue和break的区别_python中break语句和continue语句的区别
- 简单学Python——关键字6——break和continue
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
- Python 中 break 和 continue 傻傻分不清
- python中的流程控制语句:continue、break 和 return使用方法
- L017:continue和break - 教程文案
- 作为前端开发者,你都经历过怎样的面试?
- 面试被问 const 是否不可变?这样回答才显功底
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)
