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)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 19:04:23
下一篇 2025年12月2日 19:04:44

相关推荐

  • 网络进化!

    Web 应用程序从静态网站到动态网页的演变是由对更具交互性、用户友好性和功能丰富的 Web 体验的需求推动的。以下是这种范式转变的概述: 1. 静态网站(1990 年代) 定义:静态网站由用 HTML 编写的固定内容组成。每个页面都是预先构建并存储在服务器上,并且向每个用户传递相同的内容。技术:HT…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 网页设计css样式代码大全,快来收藏吧!

    减少很多不必要的代码,html+css可以很方便的进行网页的排版布局。小伙伴们收藏好哦~ 一.文本设置    1、font-size: 字号参数  2、font-style: 字体格式 3、font-weight: 字体粗细 4、颜色属性 立即学习“前端免费学习笔记(深入)”; color: 参数 …

    2025年12月24日
    000
  • css中id选择器和class选择器有何不同

    之前的文章《什么是CSS语法?详细介绍使用方法及规则》中带了解CSS语法使用方法及规则。下面本篇文章来带大家了解一下CSS中的id选择器与class选择器,介绍一下它们的区别,快来一起学习吧!! id选择器和class选择器介绍 CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用…

    2025年12月24日
    000
  • CSS如何实现任意角度的扇形(代码示例)

    本篇文章给大家带来的内容是关于CSS如何实现任意角度的扇形(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 扇形制作原理,底部一个纯色原形,里面2个相同颜色的半圆,可以是白色,内部半圆按一定角度变化,就可以产生出扇形效果 扇形绘制 .shanxing{ position:…

    2025年12月24日
    000
  • php约瑟夫问题如何解决

    “约瑟夫环”是一个数学的应用问题:一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数, 再数到第m只,在把它踢出去…,如此不停的进行下去, 直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。…

    好文分享 2025年12月24日
    000
  • Redis配置文件redis.conf详细配置说明

    本文列出了redis的配置文件redis.conf的各配置项的详细说明,简单易懂,有需要的盆友可以参考哦。 redis.conf 配置项说明如下 redis配置文件详解 # vi redis.confdaemonize yes #是否以后台进程运行pidfile /var/run/redis/red…

    好文分享 2025年12月24日
    000
  • CSS的Word中的列表详解

    在word中,列表也是使用频率非常高的元素。在css中,列表和列表项都是块级元素。也就是说,一个列表会形成一个块框,其中的每个列表项也会形成一个独立的块框。所以,盒模型中块框的所有属性,都适用于列表和列表项。 除此之外,列表还有 3 个特有的属性 list-style-type、list-style…

    2025年12月24日
    000
  • CSS新手整理的有关CSS使用技巧

    [导读]  1、不要使用过小的图片做背景平铺。这就是为何很多人都不用 1px 的原因,这才知晓。宽高 1px 的图片平铺出一个宽高 200px 的区域,需要 200*200=40, 000 次,占用资源。  2、无边框。推荐的写法是     1、不要使用过小的图片做背景平铺。这就是为何很多人都不用 …

    好文分享 2025年12月23日
    000
  • CSS中实现图片垂直居中方法详解

    [导读] 在曾经的 淘宝ued 招聘 中有这样一道题目:“使用纯css实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直居中。”当然出题并不是随意,而是有其现实的原因,垂直居中是 淘宝 工作中最 在曾经的 淘宝UED 招聘 中有这样一道题目: “使用纯CSS实现未知尺寸…

    好文分享 2025年12月23日
    000
  • CSS派生选择器

    [导读] 派生选择器通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁。在 css1 中,通过这种方式来应用规则的选择器被称为上下文选择器 (contextual selectors),这是由于它们依赖于上下文关系来应 派生选择器 通过依据元素在其位置的上下文关系来定义样式,你可以使标…

    好文分享 2025年12月23日
    000
  • CSS 基础语法

    [导读] css 语法 css 规则由两个主要的部分构成:选择器,以及一条或多条声明。selector {declaration1; declaration2;     declarationn }选择器通常是您需要改变样式的 html 元素。每条声明由一个属性和一个 CSS 语法 CSS 规则由两…

    2025年12月23日
    300
  • CSS 高级语法

    [导读] 选择器的分组你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明。用逗号将需要分组的选择器分开。在下面的例子中,我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。h1,h2,h3,h4,h5 选择器的分组 你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明…

    好文分享 2025年12月23日
    000
  • CSS id 选择器

    [导读] id 选择器id 选择器可以为标有特定 id 的 html 元素指定特定的样式。id 选择器以 ” ” 来定义。下面的两个 id 选择器,第一个可以定义元素的颜色为红色,第二个定义元素的颜色为绿色: red {color:re id 选择器 id 选择器可以为标有特…

    好文分享 2025年12月23日
    000
  • 有关css的绝对定位

    [导读] 定位(左边和顶部) css定位属性将是网虫们打开幸福之门的钥匙: h4 { position: absolute; left: 100px; top: 43px }这项css规则让浏览器将 的起始位置精 确地定在距离浏览器左边100象素,距离其 定位(左边和顶部) css定位属性将是网虫们…

    好文分享 2025年12月23日
    000
  • html5能否禁用搜索框自动填充_html5autocomplete关闭方法【教程】

    禁用HTML5搜索框自动填充有五种方法:一、设autocomplete=”off”;二、随机化name/id值;三、用无效autocomplete值如”nope”;四、JS动态设置autocomplete;五、设autocomplete=”…

    2025年12月23日
    000
  • html5怎么加php_html5用Ajax与PHP后端交互实现数据传递【交互】

    HTML5不能直接运行PHP,需通过Ajax与PHP通信:前端用fetch发送请求,PHP接收处理并返回JSON,前端解析响应更新DOM;注意跨域、编码、CSRF防护和输入过滤。 HTML5 本身是前端标记语言,不能直接运行 PHP 代码,但可以通过 Ajax(异步 JavaScript)与 PHP…

    2025年12月23日
    300
  • 手机端怎么运行html文件_手机端运行html文件方法【教程】

    可通过手机浏览器、代码编辑器、本地服务器或在线工具四种方式预览HTML文件:一、用文件管理器打开HTML并选择浏览器即可渲染页面;二、使用Acode等编辑器导入文件后点击预览功能实时查看;三、对复杂项目可用KSWEB搭建本地服务器,将文件放入指定目录后通过http://127.0.0.1:8080访…

    2025年12月23日
    000
  • html5怎么插入文档_HT5用object或iframe嵌入PDF/Word文档显示【插入】

    可在HTML5中用iframe或object标签嵌入PDF,需设宽高及可访问路径;Word文档需借OneDrive等第三方服务代理渲染;须处理跨域限制并提供下载降级方案。 如果您希望在HTML5页面中嵌入PDF或Word文档并直接显示,可以使用或标签实现。以下是几种可行的嵌入方法: 一、使用ifra…

    2025年12月23日
    200
  • html5如何插入txt纯文本_html5txt文本嵌入与编码设置【实操】

    可通过iframe、fetch+pre、object标签或服务端预处理四种方式在HTML5中显示外部TXT文件,需重点处理字符编码(如UTF-8声明、BOM、响应头)并防范XSS风险。 如果您希望在HTML5页面中显示外部TXT纯文本文件的内容,浏览器默认不支持直接嵌入TXT文件为可渲染内容,必须通…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信