windows下自动定时mysql备份数据库方法

步骤非常的简单,就三部搞定:

1.建立bat文件,bat文件内容

 代码如下 复制代码

@echo off
set host=localhost
set username=root
set passward=ansure
set database=weihe
set backup_path=D:/db_backup/
echo "Mysql Backup , please waitting"
mysqldump -h%host% -u%username% -p%passward% --skip-lock-tables %database% > %backup_path%/%database%_%date:~0,10%.sql
echo "OK ! "

//以下是解释
第一句,bat文件的通用命令。
第二句,设置月份格式,为了文件名不重复,并且知道当前文件的生成日期,生成的格式为:back_up(2013-04-25 星期四 18_00).sql   红色的这段。
第三句,我是将mysqldump.exe从安装文件拷贝到这个目录的,目的是为了防止空格(E:/backdata/tool/mysqldump.exe这段不能有空格,空格需要非常特殊的处理,这里不写详细的)。-u后面是用户名,注意没有空格哦, -u root这样是要出错的,同样-p也是。--database后面可以跟多个数据库。

2.建立计划任务,执行bat文件

到windows的任务计划里新建一个计划任务,我的计划任务执行是1个月执行一次上面的bat文件,完整备份一次数据库,以sql的形式,一般情况下设置在凌晨3点左右。
为什么一个月一次呢,因为我们还有增量备份,如果太频繁的话,消耗磁盘空间,也会消耗大量的数据库性能。所以建议是较长的时间周期,做好增量备份就可以应付了。

3.mysql的增量备份

通过上面的方案,可以将数据库恢复到上个月的数据,但是如果只有上面的备份方案,这个月的数据就不能找回了。配合增量备份方案,就可以恢复到过去的任何时候,达到比较实用的程度。那么增量备份是怎么样备份的呢?
只需在my.ini文件末尾加上这个配置就可以了:

 代码如下 复制代码

#log
log-error=D:/backdata/logs/error.log
log_bin=D:/backdata/logs/logbin.log
long_query_time=2
log-slow-queries=D:/backdata/logs/slowquery.log

这里有用的是第二行,生成的bin文件。其它几个不是用于备份的,但感觉很有用的日志,而且占用空间不大,对于分析mysql的问题是大有好处的。

4.直接备份数据库文件

新建db_bak.bat,写入以下代码

*******************************Code Start*****************************

 代码如下 复制代码
net stop mysql
xcopy c:/mysql/data/bbs/*.* c:/db_bak/bbs/%date:~0,10%/ /S /I
net start mysql

*******************************Code End *****************************

   然后使用Windows的“计划任务”定时执行该批处理脚本即可。(例如:每天凌晨3点执行back_db.bat)
解释:备份和恢复的操作都比较简单,完整性比较高,控制备份周期比较灵活,例如,用%date:~0,10%。此方法适合有独立主机但对mysql没有管理经验的用户。缺点是占用空间比较多,备份期间mysql会短时间断开(例如:针对30M左右的数据库耗时5s左右),针对%date:~0,10%的用法参考       

时间: 2024-12-11 10:29:22

windows下自动定时mysql备份数据库方法的相关文章

windows下apache+php+mysql 环境配置方法_win服务器

一 准备 1 下载apache http://httpd.apache.org/download.cgi#apache24 httpd-2.2.22-win32-x86-openssl-0.9.8t.msi openssl表示带有openssl模块,利用openssl可给Apache配置SSL安全链接 2 下载php http://windows.php.net/downloads/releases/archives/ php-5.3.5-Win32-VC6-x86.zip 下载vc6版本 VC

Windows下Apache+Tomcat+MySQL+jsp+php的服务器整合配置经验总结

apache|js|mysql|window|服务器 Windows下Apache+Tomcat+MySQL+jsp+php的服务器整合配置经验总结 1.作者:moonsbird 题目:Windows下Apache+Tomcat+MySQL+jsp+php的服务器整合配置经验总结 时间:2004.8.19 最初发表于西南交通大学锦城驿站 2.本文是作者学习几年来学习jsp/配置服务器环境的经验总结.可以转载,但请注明出处. 开始学习jsp很久了,网上有许多关于jsp整合的例子,但存在着许多问题.

Win8系统下自动开启Bing的解决方法

  Windows8系统面市已经有一段时间了,用户安装体验win8也有一段时间,对于win8的操作,相信很多用户已经或多或少掌握了一些,但是在面对win8系统下的一些小问题还是无法自己去解决,下面我们就来分享一个win8系统下自动打开bing的解决方法,供用户参考. 问题症状: 开机自动启动默认浏览器并且打开cn.bing.com站点.问题浏览器不限于IE,即使安装了火狐.谷歌的都一样;同时,不是所有安装Win8系统的用户都会有. 解决方案: - 同时按住Win + R键,输入"gpedit.m

windows下搭建Apache+Mysql+PHP开发环境

原文:windows下搭建Apache+Mysql+PHP开发环境 要求 必备知识 熟悉基本编程环境搭建. 运行环境 windows 7(64位); Apache2.2;MySQL Server 5.5php-5.3 下载地址 环境下载 官方下载地址 Apache MySql PHP 至于我使用的版本已经上传到百度云提供大家下载了,这里就不多啰嗦了!! Apache Apache的安装和普通的应用程序安装没什么太大的区别,关键是配置.打开安装路径下的"conf\httpd.conf"文

python在windows下创建隐藏窗口子进程的方法

  本文实例讲述了python在windows下创建隐藏窗口子进程的方法.分享给大家供大家参考.具体实现方法如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 import subprocess IS_WIN32 = 'win32' in str(sys.platform).lower() def subprocess_call(*args, **kwargs): #also works for Popen. #It creates a new *hidden* window

linux中MYSQL备份数据库表(多个表)

MYSQL备份数据库表 独立备份某个数据库的某个表操作: mysql> use mysql mysql> show tables; +---------------------------+ | Tables_in_mysql           | +---------------------------+ | columns_priv              | | db                        | | event                     | | f

常用windows下远程管理Linux服务器的方法

随着互联网的 高速发展以及Linuxhttp://www.aliyun.com/zixun/aggregation/13760.html">企业应用的成熟,Linux被广泛应用于服务器领域,如何实现Linux的远程管理成为 网络管理员的首要任务.我们经常见到的几种最为常用的windows下远程管理Linux服务器的方法,基本上都是利用SecureCRT,F-Secure SSH 抑或是PUTTY等客户端工具通过ssh服务来实现Windows下管理Linux服务器的,这些客户端工具几乎不需要

在Windows下自动备份PostgreSQL的教程_数据库其它

背景在我工作上一个使用PostgreSQL数据库的项目上需要一个自动化系统来每天执行备份.经过一番研究决定通过创建一个Windows批处理文件并添加到Windows计划任务中来实现. 下面是具体步骤: 怎样配置第一步: 下载批处理文件. 第二步: 你可以通过一个简单的命令(schtasks /?查看帮助)或者使用图形界面(开始-控制面板-系统和安全-管理工具-任务计划程序)运行任务计划管理工具,还可以在%SYSTEMROOT%\System32目录下双击Taskschd.msc来启动它.   第

mssql定时备份数据库方法

mssql定时备份数据库教程方法 //方法一 要用远程数据库可以备份本地. 本地数据库也可以备份到远程. --备份环境:把数据库服务器(192.168.1.8)的数据库(TEST)备份到(192.168.1.145)的C$下 --首先,做一个与客户端的映射 exec master..xp_cmdshell 'net use z: \192.168.1.145c$ "密码" /user:192.168.1.145administrator' --其次,进行数据库备份 backup dat