千家信息网

菜鸟学Linux 第078篇笔记 mysql 备份mysqldump

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,菜鸟学Linux 第078篇笔记 mysql 备份mysqldump内容总览备份类型、备份类型详解备份工具mysqldump实现备份还原MySQL的备份和还原备份:副本RAID1,RAID10 保证硬
千家信息网最后更新 2025年11月07日菜鸟学Linux 第078篇笔记 mysql 备份mysqldump

菜鸟学Linux 第078篇笔记 mysql 备份mysqldump




内容总览

备份类型、备份类型详解

备份工具

mysqldump实现备份还原






MySQL的备份和还原

备份:副本


RAID1,RAID10 保证硬件损坏而不会影响业务中止



备份类型

热备份、温备份、冷备份

热备份:读、写不受影响

温备份:仅可执行读操作

冷备份:离线备份 读、写操作均中止


物理备份、逻辑备份

物理备份:直接复制数据文件

逻辑备份:将数据导出至文本文件中


完全备份、增量备份和差异备份

完全备份:备份全部数据

增量备份:仅备份上次完全备份或增量备份以后变化的数据

差异备份:仅备份上次完全备份以来变化的数据


增量和差异区别:增量是每次备份是比较与前一次的区别并进行备份

差异是与第一次完全备份作比较,并将有差异的备份

(差异相对浪费硬盘空间一些,易于管理)


备份可自由根据需求来组合

在线物理完全备份

在线逻辑增量备份...





热备份(技术复杂度最高)

MyISAM lvm 热备 温备

InnoDB 支持热备 xtrabackup, mysqldump

冷备 mysql --> 从



物理备份 速度快,移植性不是特别好

逻辑备份 速度慢,会丢失浮点数精度,

方便使用文本处理工具直接对其处理,可移植能力强




备份策略: 完全+增量;完全+差异

数据变量的频度,和变化量

可以忍受的还原时长



备份的东东

数据、配置文件、二进制日志、事务日志


还原 测试,预演,多人分工,还原紧急处理方案



MySQL备份工具:

mysqldump 逻辑备份工具 冷备 MyISAM(温) InnoDB(热)

mysqlhostcopy 物理备份工具 温备份


文件系统工具

cp 冷备

lv 逻辑卷的快照功能,几乎热备

mysql> FLUSH TABLES;

mysql> LOCK TABLES;


创建快照:释放锁,而后复制数据即可

InnoDB:


第三组工具:

ibbackup (InnoDB) 商业工具

xtrabackup 开源工具





mysqldump 逻辑备份

mysqldump (完全备份) + 二进制日志

完全+增量


mysqldump DB_NAME [tb1] [tb2]


--master-data={0|1|2}

0 不记录二进制日志文件及其事件位置

1 以CHANGE MASTER TO方式记录位置,可用于恢复后直接启动从服务器

2 以CHANGE MASTER TO的方式记录位置,但默认被注释


--lock-all-tables 锁定所有表


--flush-logs 执行日志flush


如果指定库中的表类型均为InnoDB,可使用--single-transaction启动热备

(不要和--lock-all-tables一起使用)


--events

--routines

--triggers


备份多个库

--all-databases 备份所有库

--databases DB_NAME1,DB_NAME2 备份指定库

(使用此种备份,恢复时则不需要自己手动新建数据库名)




实验备份和还原


备份策略: 每周完全+每日增量

完全备份:mysqldump

增量备份:备份二进制日志文件(flush logs)



1.备份数据库

完全备份(备份文件要放在其它硬盘这里做测试所以只是放在其它目录里了)

# mysqldump -uroot -p --master-data=2 --flush-logs --all-databases \

--lock-all-tables > /root/all-dbs.sql

(此为一行命令)

mysql> PURGE BINARY LOGS TO 'mysql-bin.000007'; (不建议删除,只是为了做测试)

可以备份后再删除掉


做增量备份(第二天)

mysql> FLUSH LOGS;

将滚动后的日志备份(直接复制即可) 前边的目录是二进制日志所放目录

cp /mydata/data/mysql-bin.000007 /root/binary-`date +%Y-%m-%d`.sql

mysqlbinlog /mydata/data/mysql-bin.000007 > /root/monday-incremental.sql

(推荐此上条备份二进制日志文件)


第三天做增量和此一样 模拟此天不小心把数据库给删除了

(但是造成不要把二进制日志删除了哈,,这要没了就挂了)

先将二进制文件复制出来

cp /mydata/data/mysql-bin.000008 > /root/mysql-bin.000008.sql

# rm -rf /mydata/data/* (模拟数据库损坏)




还原数据库

由于我模拟的太暴力直接把库文件也给删除了所以需要重新初始化数据库

# killall mysqld

初始化数据库

# ./scripts/mysql_install_db --user=mysql --datadir=/mydata/data


还原完全备份

# mysql -uroot -p < /root/all-dbs.sql


导入增量备份

# mysql -uroot -p < /root/monday-incremental.sql (使用的是mysqlbinlog)


最后一步把最后一次的二进制日志导入到数据库

# mysqlbinlog mysql-bin.000008.sql | mysql -uroot -p

(到此步便为即时点还原)


mysqldump虽然可以实现备份还原,但是会丢失精度,只适合小型的数据库



最后作业

脚本完成完全备份

脚本完成增量备份

并添加至任务计划让其自动执行备份

(目前个人未做出来)










备份 数据 增量 日志 二进制 工具 数据库 文件 差异 逻辑 物理 备份工具 类型 位置 目录 变化 处理 测试 只是 快照 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 搜索一个网络安全手抄报 服务器远程重启工具 ipad苹果服务器出错怎么办 某公司主要通过系统数据库 pg数据库怎么创建临时表 嵌入式软件开发工资怎么样 城市科技创新和产业互联网 mongodb切换数据库目录 web部署到服务器上 中山丹皓软件开发有限公司 青岛海房屋网络技术有限公司 地理数据库能链接到文件夹吗 云南专业模具软件开发费用 天正v5.0服务器为空 电教管理服务器厂家 云南计算机网络技术院校报名 出入库数据库表设计 年度网络安全工作情况汇报 sql数据库名称重复 做数据开发和软件开发 网络安全风险隐患通报 数据库什么是完全函数依赖 服务器ping延迟高cpu正常 软件开发工作招聘信息 计算机网络技术从事的工作 建立健全网络安全考核机制 网络安全职业技能大赛训练题 北京多媒体软件开发公司 深圳服务器电源哪种好 网络安全知识宣传小漫画来啦
0