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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

菜鸟学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虽然可以实现备份还原,但是会丢失精度,只适合小型的数据库



最后作业 

脚本完成完全备份

脚本完成增量备份

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

(目前个人未做出来)

本文转自Winthcloud博客51CTO博客,原文链接http://blog.51cto.com/winthcloud/1891676如需转载请自行联系原作者


Winthcloud

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
16天前
|
关系型数据库 MySQL Linux
MySQL数据库下载安装教程(Windows&Linux)
本文档详细介绍了MySQL的安装步骤,包括安装前的准备工作、下载安装包、Windows和Linux系统下的具体安装流程,以及如何配置MySQL服务、设置环境变量、启动服务和连接数据库等关键操作。
|
1月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
94 3
|
1月前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
45 3
|
1月前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
110 3
|
2月前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
110 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
2月前
|
Ubuntu 关系型数据库 MySQL
Linux系统MySQL安装
【10月更文挑战第19天】本文介绍了在 Linux 系统上安装 MySQL 的步骤,包括安装前准备、安装 MySQL、启动 MySQL 服务、配置 MySQL 以及验证安装。适用于 Ubuntu/Debian 和 CentOS/Fedora 系统,提供了详细的命令示例。
285 1
|
7月前
|
存储 关系型数据库 MySQL
LINUX中的mysql(一)安装
MySQL是一种常用的开源关系型数据库管理系统,广泛应用于Linux系统中。它提供了一个灵活、高效和可扩展的数据库解决方案,被许多应用程序和网站用于存储和管理数据。
189 0
|
关系型数据库 MySQL Linux
【Linux】jdk & Tomcat & MySql的安装及Linux后端接口部署
【Linux】jdk & Tomcat & MySql的安装及Linux后端接口部署
155 0
|
4月前
|
关系型数据库 MySQL Linux
Linux环境安装MySQL8.0.36使用rpm包安装,安装顺序是什么?
【8月更文挑战第23天】Linux环境安装MySQL8.0.36使用rpm包安装,安装顺序是什么?
365 1
|
5月前
|
关系型数据库 MySQL Linux
Linux部署实战前言,MySQL在CentOS安装【单机软件】,MySQL的安装需要root权限,yum install mysql,systemctl enable mysqld开机自启的意思
Linux部署实战前言,MySQL在CentOS安装【单机软件】,MySQL的安装需要root权限,yum install mysql,systemctl enable mysqld开机自启的意思
下一篇
DataWorks