热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql备份:完全备份和增量备份_MySQL

mysql备份:完全备份和增量备份
bitsCN.com

mysql备份:完全备份和增量备份

完全备份:

在cmd下进入该mysql目录下bin目录,mysqldump.exe来执行备份。mysqldump -uroot -p911004 数据库或则数据表>路劲/文件名。在mysql控制台上,恢复时用source 路径/备份文件名

完整备份一般一段时间进行一次,且在网站访问量最小的时候,这样常借助批处理文件定时备份。主要是写一个批处理文件在里面写上处理程序的绝对路径然后把要处理的东西写在后面,即完全备份数据库C:/myenv/mysql5.5.27/bin/mysqldump -u root -proot temp dept > d:/temp.dept.bak。然后在控制面板上,创建任务。任务指定该批处理文件的执行时间。但是执行一次该文件产生的备份都会覆盖上一次的文件。需要一个动态指定的名字,借助php可以实现,那么这次在批处理文件里面写的是php.exe /php文件路径/*.php。在php文件里面,可以根据时间生成文件的名字,写备份语句,让exec函数执行。在创建计划让每个一段时间执行一次文件。

php文件:

date_default_timezone_set('PRC');

$bakfilename=date("YmdHis",time());

$command="C:/myenv/mysql5.5.27/bin/mysqldump-u root -proot temp dept > d://{$bakfilename}";

exec($command);

增量备份:

对ddl和dml语句进行二进制备份。且5.0无法增量备份,5.1后可以。

如果要实现增量备份需要在my.ini文件中配置备份路径即[mysqld]下的log-bin='d:/log/mylog'

重启mysql服务器,增量备份就启动了。

会在指定目录下生成两个文件mylog.index记录索引,mylog.000001就是记录二进制的详细信息。

如果要查看必须使用mysqlbinlog工具查看。在cmd中进入mysql目录下的bin中 使用msyqlbinlog

后面加上mylog.000001,可以看到所有ddl和dml操作,且每一个操作都有具体的位置和时间点的记录。

根据这些信息,可以恢复操作,

主要可以通过时间和位置两种方式恢复:

mysqlbinlog --stop-datetime="2013-01-14 18:20:21" d:/log/mylog.000001 | mysql -uroot -p911004

从开始到这个时间点

mysqlbinlog --start-datetime="2013-01-14 18:20:21" d:/log/mylog.000001 | mysql -uroot -p911004

从这个时间点到最后

mysqlbinlog --start-datetime="2013-01-14 18:20:21" --stop-datetime="2013-01-14 18:20:21" d:/log/mylog.000001 | mysql -uroot -p911004

恢复这一个时间段的数据。

mysqlbinlog --stop-position=“N” d:/log/mylog.000001 | mysql -uroot -p911004

从开始到这个地方

mysqlbinlog --start-position="2013-01-14 18:20:21" d:/log/mylog.000001 | mysql -uroot -p911004

从这个地方到最后

mysqlbinlog --start-position="2013-01-14 18:20:21" --stop-position="2013-01-14 18:20:21" d:/log/mylog.000001 | mysql -uroot -p911004

恢复这一个地方段的数据。随着时间的推移,二进制文件里面的数据越来越大,所以要定期的做一些清理工作。

1.reset master 可以删除列于索引文件中的所有二进制日志,

把二进制日志索引文件重新设置为空,并创建一个新的二进制日志文件

2.PURGE {MASTER | BINARY} LOGS TO 'log_name'

PURGE {MASTER | BINARY} LOGS BEFORE 'date'

用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。

这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个。

3.设置my.ini中的参数[mysqld]下的-EXPIRE_LOGS_DAYS。此参数是设置日志的过期天数,过期的日志将会被自动删除,

一般一周做一次全备份,之后增量备份,且过期时间大于7天。如果全奔溃了,先全恢复,在增量恢复。如果误操作可以看增量日志进行增量恢复。

bitsCN.com
推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 给定一个二维平面上的一些点,通过计算曼哈顿距离,求连接所有点的最小总费用。只有任意两点之间有且仅有一条简单路径时,才认为所有点都已连接。给出了几个示例并给出了对应的输出。 ... [详细]
author-avatar
拍友2502875873
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有