Mysql的备份和恢复

mysql的备份分类:
mysql的数据备份:
 逻辑备份、物理备份
mysql按照数据集分类:
 完全备份
 增量备份
 差异备份
一般这几种都是组合起来使用的,比如完全备份可以一周进行一次,增量备
份和差异备份可以一天备份一次,但是这要根据企业的业务逻辑而定,所以
合适的选择,将会在数据恢复的时候将损失降到最低。
mysql按照服务器是否停机分类:
 冷备份:服务完全停止
 温备份:服务不关闭,但是在备份的时候,其他的事务只有查询的操作
 热备份:服务在线,不影响读写(但是非事务存储引擎的很难实现热备,但
是可以使用lvm实现几乎热备的功能)
需要备份的东西:
 1.数据文件
 2.日志文件(事务日志,二进制日志)
 3.存储过程,存储函数,触发器
 4.配置文件
日志分类:
 1.事务日志:
   随机io转换成顺序io
   事件重放(撤销)提供基础
 2.事件事务:
   记录历史时间
mysql的日志文件
  1.the error log 错误日志
     错误信息,服务器进程启动或停止产生的信息,主从中添加复制的时
候,也会记录
     主配置文件启动错误日志,
     log_error=/var/log/mysqld.err(确保对mysqld有写的权限)
  2.the binary log 二进制日志
     提供增量备份
     基于时间点的恢复
     复制架构提供基础
     log_bin=/data/logs/binary/changelog (默认在数据文件中)
     log_bin_index=/data/logs/relay/binarylog 定义二进制文件的索引
位置
  3.the general query log  平时建议不开
      general_log=on|off
      general_log_file=/path
  4.the slow query log 慢查询日志
      slow_query_log=on
      slow_query_log_file=/path
      long_query_time=num 定义超时时间
  5.relay log 中继日志
  默认mysql不开启任何日志,但在mysqld脚本中开启了错误日志(the
error log)

mysql常用的备份工具:
mysqldump
SELECT INTO OUTFILE
mk-parallel-backup
ibbackup
mysqlhostcopy (MyISAM存储引擎的几乎冷备份,看着名字像是热备)
 
接下来我将借助我的一个简单的数据库进行演示数据的备份和还原的过程:
1.使用mysqldump来备份
 mysqldump的备份是一个逻辑备份;
 备份的格式如下;
 #mysqldump db_name [table_name] > /PATH
 当然mysqldump的备份还有很多选项:
  –all-databases 备份所有的数据库
  –events 备份事件
  –routines 备份存储函数
  –triggers 备份触发器
  –extended-insert  备份扩展的插入
  –skip-extended-insert  关闭备份扩展的插入
  –lock-all-tables 加锁,这个是必须的
  –flush-logs 刷新日志文件到磁盘中去,也是必须的
  –master-data=n{0|1|2} 做复制的时候用到(2)
  –no-data 只备份数据库中的表结构
  –where  “WHERE CLAUSE” 备份指定的数据
mysql> CREATE DATABASE luowei;
mysql> SHOW DATABASES;//查看所有的数据库
+——————–+
| Database           |
+——————–+
| information_schema |
| luowei             |
| mysql              |
| ndodb              |
| test               |
+——————–+
mysql> USE luowei;
mysql> CREATE TABLE st (
    -> ID INT UNIQUE AUTO_INCREMENT,
    -> Name VARCHAR(30) );
mysql> SHOW TABLES; //查看表
+——————+
| Tables_in_luowei |
+——————+
| st               |
+——————+
mysql> INSERT INTO st  (Name) VALUE (‘a’),(‘b’),(‘c’);
mysql> SELECT * FROM st; //显示表中的数据
+—-+——+
| ID | Name |
+—-+——+
|  1 | a    |
|  2 | b    |
|  3 | c    |
+—-+——+
这是我的数据库中原始的信息,因为等会要删掉数据库和表,所以先看一下
里面的数据,方便等会验证;
[root@nfs ~]# mysqldump -uroot -p luowei st > /root/st.sql  //开始
备份表st,这里没有使用任何参数的
Enter password:
OK,这个时候备份完了,由于mysqldump使用的是逻辑备份,所以备份下来
的是一些create、insert语句
我们可以打开看一下
[root@nfs ~]# cat /root/luoweidb | grep -v “^/” | grep -v  “^$”
— MySQL dump 10.11

— Host: localhost    Database: luowei
— ——————————————————
— Server version 5.0.77

— Current Database: `luowei`

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `luowei` /*!40100 DEFAULT
CHARACTER SET latin1 */;
USE `luowei`;

— Table structure for table `st`

DROP TABLE IF EXISTS `st`;
SET @saved_cs_client     = @@character_set_client;
SET character_set_client = utf8;
CREATE TABLE `st` (
  `ID` int(11) NOT NULL auto_increment,
  `Name` varchar(30) default NULL,
  UNIQUE KEY `ID` (`ID`)
) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=latin1;
SET character_set_client = @saved_cs_client;

— Dumping data for table `st`

LOCK TABLES `st` WRITE;
INSERT INTO `st` VALUES (1,’a’),(2,’b’),(3,’c’);
UNLOCK TABLES;
— Dump completed on 2011-09-05  8:00:08
看到了吧,这里面是整个我刚做过的创建数据库,创建表,插入数据的语句

接下来,我们做一下数据库恢复:
[root@nfs ~]# mysql -uroot -e   “DROP DATABASE luowei;” -p //删除
数据库
Enter password:
[root@nfs ~]# mysql -uroot -e   “SHOW DATABASES;” -p //查看删除后
的数据库
Enter password:
+——————–+
| Database           |
+——————–+
| information_schema |
| mysql              |
| ndodb              |
| test               |
+——————–+
我把luowei的数据库给删除了,现在将进行数据库的恢复
[root@nfs ~]# mysql -uroot -p < /root/luoweidb
Enter password:
[root@nfs ~]# mysql -e “SHOW DATABASES;”
+——————–+
| Database           |
+——————–+
| information_schema |
| hellodb            |
| luowei             |
| mysql              |
| ndodb              |
| test               |
+——————–+
OK ,数据库是恢复过来了,接下来就是查看表中的信息是否完整了
[root@nfs ~]# mysql -e “SELECT * FROM luowei.st” -uroot -p
Enter password:
+—-+——+
| ID | Name |
+—-+——+
|  1 | a    |
|  2 | b    |
|  3 | c    |
+—-+——+
Ok,一起安好,呵呵,当然其他的参数就不做详细介绍了,需要用到的话,
可以使用HELP命令寻求帮助。
下面介绍一个本机不用输入Mysql密码的方法:
#vim /root/.my.cnf
 [client]
 user = root
 password = redhat
保存起来,下次对数据库的操作就直接使用mysql命令了,不用在输入密码
了;
接下来的实验我也就不输入密码了;

2.使用SELECT INTO OUTFILE 的方法进行备份
还是用上面的表,
[root@nfs ~]# mysql -e “SELECT * FROM luowei.st”
+—-+——+
| ID | Name |
+—-+——+
|  1 | a    |
|  2 | b    |
|  3 | c    |
+—-+——+
如果想把ID小于等于2的备份出来,就可以使用这种方法备份了
mysql> SELECT * INTO OUTFILE ‘/tmp/st.bak’ FROM st WHERE ID <=2;
[root@nfs ~]# cat /tmp/st.bak
1 a
2 b
我们可以看到一个文本文件,类似于表,但是这种方法只备份数据本身,不
备份表结构,所以恢复的时候,就需要按照结构重新建立一个新表,然后在
恢复
mysql> CREATE TABLE mt LIKE st; //我这里新创建一个基于st表格式的新
表mt,然后把刚备份的数据恢复到新表mt中,这也类是与恢复到原表了,呵
呵,小偷懒一下!!!
mysql> LOAD DATA INFILE ‘/tmp/st.bak’ INTO TABLE mt;
mysql> SELECT * FROM mt;
+—-+——+
| ID | Name |
+—-+——+
|  1 | a    |
|  2 | b    |
+—-+——+
ok了,我们现在来总结一下这两种方法,首先使用mysqldump备份的数据使
用逻辑备份的方式,备份的是一些对数据库的操作的语句,恢复简单;而使
用SELECT INTO OUTFILE这种可以备份指定的数据,有选择性的备份数据,
但是在恢复的时候就要麻烦一点,还要创建表。

3.基于LVM的快照备份:
操作步骤:
 a.确保数据文件在LV上
 b.对数据库中的表施加读锁
 c.对数据所在的LV做快照
 d.释放数据库的读锁
 e.挂载快照卷,备份数据文件(对于InnoDB存储引擎,同时备份事务日志
文件)
 f.删除快照
使用LVM做快照备份的条件是:
  >SHOW VARIABLES LIKE ‘log_binlog’;处于ON
  >SHOW VARIABLES LIKE ‘sync_binlog’改为1
  >SHOW VARIABLES LIKE ‘innodb_support_xa’ 处于ON的状态
LV快照备份 
#mysql
>FLUSH TABLES WITH READ LOCK; //加上读锁
# lvcreate -L 50M -n mysnap -s /dev/myvg/mydata  //创建快照
>UNLOCK TABLES; //解锁
#mount /dev/myvg/mysnap /mnt  //挂载快照卷
#cd /mnt/data
#tar -jcf /root/mysql.tar.bz2 luowei/ ibdata1 ib_logfile* mysql-
bin.*  //备份数据并压缩
#umount /mnt  //卸载快照
#lvremove –force /dev/myvg/mysnap  //移除快照
 
LV恢复
cd /usr/local/mysql
#chown -R mysql:mysql . //修改权限
#scripts/mysql_install_db –user=mysql –datadir=/mydata/data/  //
重新生成
#chown -R root .
#killall mysqld  //杀掉所有关于mysql的进程
#cd /mydata/data
#tar xf /root/mysql.tar.bz2 -C ./  //把备份恢复到mysql的数据文件中
然后我们在登录到Mysql,就会发现原来的数据仍然存在了

和茶网商城电脑版加手机版 和茶网商城电脑版加手机版

和茶网商城电脑版加手机版是以ecshop为核心进行开发的和茶网商城电脑版加手机版源码。安装步骤:1、打开:网址/diguo/index.php 用户密码是admin 123456 登录进去配置数据库信息。2、用帝国还原恢复数据库.3、修改data文件夹里的config.php (data/config.php)数据库配置信息4、登录网站后台,网址:域名/admin/index.php 后台帐

和茶网商城电脑版加手机版 0 查看详情 和茶网商城电脑版加手机版

4.使用binary日志文件实现时间点的恢复
显示当前正在使用的事务文件
mysql> FLUSH TABLES WITH READ LOCK;
mysql> SHOW MASTER STATUS;
+——————+———-+————–+——————+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———-+————–+——————+
| mysql-bin.000006 |      330 |              |                  |
+——————+———-+————–+——————+
mysql> FLUSH LOGS; //滚动日志文件
再查看正在使用的事务文件,然后记录下这个Position就行了
由于二进制日志文件只记录数据修改的信息,所以每次的修改对应的
Position都会改变
现在我向表中插入一行数据
mysql> INSERT INTO st (Name) VALUE (‘d’);
mysql> INSERT INTO st (Name) VALUE (‘E’);
mysql> SHOW MASTER STATUS;
+——————+———-+————–+——————+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———-+————–+——————+
| mysql-bin.000007 |      553 |              |                  |
+——————+———-+————–+——————+
由于我们前面已经做了一个完全备份,所有我们现在可以备份从330开始的
数据了
# mysqlbinlog –start-position 330 mysql-bin.000007
>/root/mysql.incr.sql //备份增加的二进制文件
然后我们这个时候登录到mysql
mysql>DROP DATABASE luowei;
然后恢复该数据库
# service mysqld stop
# scripts/mysql_install_db –user=mysql –datadir=/mydata/data/
# cd /mydata/data/
# tar xf /root/mysql.incr.sql -C .
# mysql < /root/mysql.incr.sql
# service mysqld start
登录到数据库,
就会发现有数据恢复正常

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1081899.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何美化type=range输入使其像播放器进度条?
上一篇 2025年12月2日 19:04:32
Golang map初始化语法与常见用法
下一篇 2025年12月2日 19:04:37

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    100
  • 获取日期中的周数:CodeIgniter 教程

    本教程旨在帮助开发者在 CodeIgniter 框架中,从日期字符串中准确提取周数。我们将使用 PHP 内置的 DateTime 类,并提供详细的代码示例和注意事项,确保您能够轻松地在项目中实现此功能。 使用 DateTime 类获取周数 PHP 的 DateTime 类提供了一种便捷的方式来处理日…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    000
  • PHP动态生成表单输入与POST数据获取实践指南

    本教程详细阐述了如何在php中根据动态数据源(如数据库值)生成多个表单输入框,并演示了如何通过post方法准确无误地获取这些动态生成的输入值。文章强调了正确的输入框命名策略,避免了常见的命名误区,并提供了完整的代码示例,确保开发者能够高效处理动态表单数据。 动态生成表单输入 在Web开发中,我们经常…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    000
  • JavaScript函数中插入加载动画(Spinner)的正确方法

    本文旨在解决在JavaScript函数中插入加载动画(Spinner)时遇到的异步问题。通过引入async/await和Promise.all,确保在数据处理完成前后正确显示和隐藏加载动画,提升用户体验。我们将提供两种实现方案,并详细解释其原理和优势。 在Web开发中,当执行耗时操作时,显示加载动画…

    2026年5月10日
    000
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • PHP多维数组到复杂XML结构的SOAP序列化实践

    本文旨在解决php多维数组向复杂soap xml结构序列化时遇到的“无法序列化结果”问题。通过深入理解soap xml的结构要求,包括命名空间和类型属性,文章将指导您如何构建符合特定xml schema的php关联数组。我们将利用`spatie/array-to-xml`库,详细演示其安装与使用方法…

    2026年5月10日
    000
  • 使用 Ajax 和 FormData 实现文件上传及文本数据提交的完整教程

    本文旨在解决在使用 Ajax 和 FormData 进行文件上传时,遇到的 $_POST 和 $_FILES 为空的问题。通过详细的代码示例和解释,我们将展示如何正确地构建 FormData 对象,并通过 Ajax 将文件和文本数据发送到服务器端,同时避免常见的错误配置,确保数据能够成功地被 PHP…

    2026年5月10日
    000
  • 虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版

    虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版

    虫虫漫画官网入口为www.ccmh.com,用户可直接通过浏览器访问,支持多端适配与账号同步功能,界面简洁无广告,提供海量国漫、日漫、韩漫资源,涵盖恋爱、玄幻等热门题材,更新及时,支持多种阅读模式及离线缓存,阅读体验流畅。 虫虫漫画直接进入官网入口在哪里?这是不少网友都关注的,接下来由PHP小编为大…

    2026年5月10日 用户投稿
    100
  • 从 JavaScript 获取 URL 并在 PHP DataGrid 中使用

    本文档旨在指导开发者如何从 JavaScript 函数中获取 URL,并将其动态应用于 PHP DataGrid。通过前端 JavaScript 动态生成 API 地址,并将其传递给后端的 PHP DataGrid,实现数据根据用户会话动态加载。 动态配置 DataGrid 的 URL 在构建动态 …

    2026年5月10日
    000
  • 硬盘数据被误删除怎么办?教你快速找回删除的文件!

    硬盘数据被误删除,别慌!恢复数据并非不可能,关键在于你接下来的操作。立刻停止对该硬盘的任何写入操作,然后尝试使用专业的数据恢复软件。 解决方案 首先,数据恢复的原理是,删除文件后,操作系统只是将文件占用的空间标记为“可覆盖”,但文件本身的数据可能还存在于硬盘上。所以,避免新的数据写入覆盖掉旧数据,是…

    2026年5月10日
    000
  • CodeIgniter在IIS环境下实现URL重写与index.php移除指南

    本教程详细指导如何在IIS服务器上部署的CodeIgniter应用中,移除URL中不必要的index.php。核心解决方案涉及修改CodeIgniter的config.php文件,将$config[‘index_page’]设置为空,并辅以正确的IIS web.config重…

    2026年5月10日
    100
  • PHP安全文件下载:防止直链与保护资源

    本文旨在解决通过检查元素获取直链下载文件的问题,并提供一种安全的PHP服务器端文件交付方案。核心思想是利用PHP作为文件代理,通过设置HTTP响应头直接将文件发送给用户,从而隐藏文件的实际存储路径,有效防止未经授权的直接链接访问。 客户端下载链接的风险与局限性 在构建下载页面时,开发者常常面临一个挑…

    2026年5月10日
    100
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信