热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Mysql的备份和恢复_MySQL

Mysql的备份和恢复
bitsCN.com

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 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 &#39;/tmp/st.bak&#39; 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 &#39;/tmp/st.bak&#39; 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 &#39;log_binlog&#39;;处于ON
>SHOW VARIABLES LIKE &#39;sync_binlog&#39;改为1
>SHOW VARIABLES LIKE &#39;innodb_support_xa&#39; 处于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,就会发现原来的数据仍然存在了

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 (&#39;d&#39;);
mysql> INSERT INTO st (Name) VALUE (&#39;E&#39;);
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 # service mysqld start
登录到数据库,
就会发现有数据恢复正常


作者 “IT梦-齐-分享”

bitsCN.com
推荐阅读
  • Python项目实战10.2:MySQL读写分离性能优化
    本文介绍了在Python项目实战中进行MySQL读写分离的性能优化,包括主从同步的配置和Django实现,以及在两台centos 7系统上安装和配置MySQL的步骤。同时还介绍了创建从数据库的用户和权限的方法。摘要长度为176字。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了在MacOS系统上安装MySQL的步骤,并详细说明了如何设置MySQL服务的开机启动和如何修改MySQL的密码。通过下载MySQL的macos版本并按照提示一步一步安装,在系统偏好设置中可以找到MySQL的图标进行设置。同时,还介绍了通过终端命令来修改MySQL的密码的具体操作步骤。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
  • 图片复制到服务器 方向变了_双服务器热备更新配置文件步骤问题及解决方法
    本文介绍了在将图片复制到服务器并进行方向变换的过程中,双服务器热备更新配置文件所出现的问题及解决方法。通过停止所有服务、更新配置、重启服务等操作,可以避免数据中断和操作不规范导致的问题。同时还提到了注意事项,如Avimet版本的差异以及配置文件和批处理文件的存放路径等。通过严格执行切换步骤,可以成功进行更新操作。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • mysql-cluster集群sql节点高可用keepalived的故障处理过程
    本文描述了mysql-cluster集群sql节点高可用keepalived的故障处理过程,包括故障发生时间、故障描述、故障分析等内容。根据keepalived的日志分析,发现bogus VRRP packet received on eth0 !!!等错误信息,进而导致vip地址失效,使得mysql-cluster的api无法访问。针对这个问题,本文提供了相应的解决方案。 ... [详细]
author-avatar
拍友2502908871
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有