在Windows环境下使⽤MySQL:实现⾃动定时备份
⼀、编写备份脚本
rem auther:www.yumi-info
rem date:20171222
rem ******MySQL backup start********
@echo off
forfiles /p "E:\mysql\MySQL BackUp" /m backup_*.sql -d -30 /c "cmd /c del /f @path"
set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%0%time:~1,1%%time:~3,2%%time:~6,2%"
"E:\mysql\MySQL Server 5.6\bin\mysqldump" --opt --single-transaction=TRUE --user=root --password=123456 --host=127.0.0.1 --protocol=tcp --port=3306 --default-character-set=utf8 --single-transaction=TRUE --routines --events "yumi_website" > "E:\mysql\My @echo on
rem ******MySQL backup end********
这是⼀段很常见的windows批处理脚本⽂件,我来简单解释⼀下其中的关键部分:
forfiles /p "E:\mysql\MySQL BackUp" /m backup_*.sql -d -30 /c "cmd /c del /f @path"
forfiles ⽤来对备份⽬录下的过期备份进⾏删除。“E:\mysql\MySQL BackUp”是备份⽂件所在的路径,可以⾃⾏修改。“backup_*.sql”指的是该路径下所有以“backup_”开头,以“.sql”作为后缀的数据库备份
⽂件。⽽后⾯的数字“30”表⽰30天过期。
set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%0%time:~1,1%%time:~3,2%%time:~6,2%"
使⽤set命令来定义⼀个名为“Ymd”的变量,这个变量的值就是后⾯的⼀⼤串规则,简单说就是当前的⽇期和时间
"E:\mysql\MySQL Server 5.6\bin\mysqldump"
这⼀⾏命令就是调⽤MySQL⾃带的备份⼯具了,注意这个路径必须写成你⾃⼰的“”所在的路径,⼀般都是在MySQL安装路径的/bin⽬录下。⽽这⼀⾏命令后⾯紧跟着⼀⼤串的参数,我们
挑⼏个重要的来解释:
-
-user=root
连接MySQL数据库服务的账户,通常该账户必须具备数据库备份操作的权限。为了简便我们使⽤了root,但是在实际⽣产环境中并不建议使⽤root账户,避免账户和密码泄露,从⽽造成不必要的⿇烦。
--password=123456
这是连接MySQL数据库服务的密码
--host=127.0.0.1
这是数据库服务所在的服务器ip地址
--port=3306
这是数据库服务所在的服务器的端⼝号
--events "yumi_website" > "E:\mysql\MySQL BackUp\backup_%Ymd%.sql"
events参数即实现了将数据库备份到⼀个指定的⽂件这⼀操作。"yumi_website"是需要做备份的数据库,⽽⼤于号“>”右边的就是我们的备份⽂件所保存的服务器⽬录和⽂件名了。
⼆、设定Windows任务
完成了上述步骤后,我们需要添加Windows计划任务。
在Windows Server2012中,我们进⼊服务器管理⾯板,点击右上⾓菜单栏中的“⼯具”,选择其中的“任务计划程序”:
打开了任务计划程序之后,我们点击右侧的“创建基本任务”:
然后,我们需要填写任务的名称,以及描述信息:
点击下⼀步之后,我们需要设定任务的执⾏频率,我选择的是“每天”:
再次点击“下⼀步”,设置任务执⾏的时间,我选择了夜深⼈静的1点:
在“下⼀步”中,我们选择“启动程序”:
windows怎么使用mysql
在之后的对话框中,我们需要选择刚才所编写的批处理⽂件:
完成这些步骤后,windows会给我们看⼀下整个任务的概述信息:
确定⽆误之后,点击“完成”就可以了。此时我们就会看到在Windows的任务列表⾥,多了⼀条新的任务:
⾄此,在Windows环境下⾃动备份MySQL的设置就全部完成了。
以上这篇在Windows环境下使⽤MySQL:实现⾃动定时备份就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。