我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何优雅安全的备份MySQL数据

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何优雅安全的备份MySQL数据

1. 为什么要备份数据

先说一下为什么需要备份MySQL数据?

一句话总结就是:为了保证数据的安全性。

如果我们把数据只存储在一个地方,如果物理机器损坏,会导致数据丢失,无法恢复。

还有就是我们每次手动修改线上数据之前,为了安全起见,都需要先备份数据。防止人为的误操作,导致弄脏数据或弄丢数据。

2. 怎样备份MySQL数据?

想要快速简单粗暴备份MySQL数据,可以使用mysqldump命令:

# 备份test数据库
mysqldump -uroot -p test > backup.db

但是这样备份的可能包含脏数据,比如在我们备份数据的过程中,有个下单的操作正在执行。

下单之后,还没有来得及扣款,就开始执行备份数据的命令,就会出现脏数据。

下单,保存订单表
备份数据
扣款

3. 怎么安全的备份数据?

mysqldump命令也提供了以事务的形式备份的参数:

# 开启一个事务备份test数据库
mysqldump -uroot -p --single-transaction test > backup.db

开启事务后,会跟正常业务操作产生锁资源竞争,可能会阻塞其他的业务操作,严重的可能会导致服务宕机,所以备份操作尽量在业务低峰期执行。

还有一个问题,只有InnoDB引擎支持事务命令,对于不支持的事务MyISAM引擎,备份数据的时候怎么保证数据的安全性呢?

有一个粗暴的办法就是设置全库只读,禁止写操作,这样备份的时候不就能保证数据安全性啦。

先用命令查看一下数据库的只读状态:

show variables like 'read_only';

OFF表示只读模式关闭,ON表示开启只读模式。

set global read_only=1;

这样设置其实是非常危险的,如果客户端连接断开,整个数据库也会一直处于只读模式,无法进行写操作。

更推荐的办法是设置全局锁 FTWRL(flush tables with read lock)。

# 设置全局锁,禁止写操作
flush tables with read lock;
# 释放锁
unlock tables;

设置全局锁之后,如果客户端断开,会自动释放锁,更安全。

4. 怎么恢复数据?

通过备份文件恢复数据也非常简单:

# 把备份文件数据导入到test数据库
mysqldump -uroot -p test < backup.db

到此这篇关于如何优雅安全的备份MySQL数据的文章就介绍到这了,更多相关备份MySQL数据内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何优雅安全的备份MySQL数据

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何优雅安全的备份MySQL数据

这篇文章主要介绍了如何优雅安全的备份MySQL数据的相关资料,需要的朋友可以参考下
2022-11-13

MySQL如何优雅的备份账号相关信息

前言: 最近遇到实例迁移的问题,数据迁完后还需要将数据库用户及权限迁移过去。进行逻辑备份时,我一般习惯将MySQL系统库排除掉,这样备份里面就不包含数据库用户相关信息了。这时候如果想迁移用户相关信息 可以采用以下三种方案,类似的 我们也可以
2022-05-27

如何优雅、安全的关闭MySQL进程

前言 本文分析了 mysqld 进程关闭的过程,以及如何安全、缓和地关闭 MySQL 实例,对这个过程不甚清楚的同学可以参考下。 关闭过程 1、发起 shutdown,发出 SIGTERM 信号 2、有必要的话,新建一个关闭线程(shutd
2022-05-12

mysql数据如何备份

mysql 数据备份方法MySQL 数据备份是确保数据安全和防范数据丢失的至关重要的一步。以下几种方法可以用来备份 MySQL 数据:1. mysqldumpmysqldump 是 MySQL 官方提供的命令行工具,用于创建数据库的
mysql数据如何备份
2024-06-15

MySQL如何实现定时全库备份数据库

这篇文章给大家分享的是有关MySQL如何实现定时全库备份数据库的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、MySQL数据备份1.1、 mysqldump命令备份数据在MySQL中提供了命令行导出数据库数据以
2023-06-20

mysql数据备份如何替换

替换 mysql 数据备份的方法:停止 mysql 服务器。备份现有数据。停止 mysql 服务器。用备份副本替换数据文件。如果启用了日志记录,则替换日志文件。启动 mysql 服务器。MySQL 数据备份替换指南如何替换 MySQL 数
mysql数据备份如何替换
2024-08-01

如何使用MySQL的备份和还原技术保护数据的安全性?

如何使用MySQL的备份和还原技术保护数据的安全性?数据作为现代社会中最重要的资产之一,对于任何组织或个人来说都至关重要。在数据库管理系统中,MySQL是最受欢迎和广泛使用的开源关系数据库管理系统之一。然而,数据丢失或数据泄露风险始终存在,
2023-10-22

mysql如何备份整个数据库

在 mysql 中备份整个数据库的步骤:使用 mysqldump 工具:mysqldump -u 用户名 -p 数据库名 > 备份文件.sql执行备份安全地存储备份如何在 MySQL 中备份整个数据库步骤 1:使用 mysqldump 工
mysql如何备份整个数据库
2024-06-14

步骤:如何备份MySQL数据库

MySQL数据库备份的步骤,需要具体代码示例数据库备份是非常重要的一项工作,它能帮助我们防止数据丢失以及在需要时恢复数据。对于MySQL数据库来说,备份数据是相对简单的操作。下面将详细介绍MySQL数据库备份的步骤,并提供具体的代码示例。
步骤:如何备份MySQL数据库
2024-02-22

面对勒索软件 如何保护数据备份安全?

尽管近期攻击事件有所减少,但勒索软件仍然对企业构成了重大威胁,尤其是勒索软件编写者意识到备份是一种有效的防御措施,并且正在修改其恶意软件以追踪并消除备份。勒索软件攻击下降,但并没有消失McAfee报告称,去年恶意软件和样本的数量都有所下降。
2023-06-04

编程热搜

目录