请问mysql怎么自动备份数据库?

作者&投稿:狂萧 (若有异议请与网页底部的电邮联系)
请问mysql怎么自动备份数据库?~

直接利用第三方工具“多备份”来实现MySQL自动备份数据库吧,非常方便,可以设置按时/天/周/月/频率进行设置自动增量备份,兼容windows、Linux、Unix等系统,在线就可以一键恢复,不需要写php代码

打开navicat客户端,连上mysql后,双击左边你想要备份的数据库。点击“计划”,再点击“新建批处理作业”。

双击上面的可用任务,它就会到下面的列表里去,代表你选择了这个任务。

点击保存,弹出个命名对话框,给这个任务取个名字,点击“确定”。

点击“设置”计划任务。

弹出的对话框,选择“计划”,再点击“新建”。

这里设置为从2014年1月24号起每天早上九点备份该数据库。如果你想提高备份频率、或者设置备份截止日期,请点击“高级”。


高级选项可以把备份设置的更精细,比如这里设置的是在24小时内每隔2小时就备份一次。加上前面的基本设置,任务计划就是:从2014年1月24号开始,每天九点,每隔2小时备份一次,每天的备份都持续24小时。

最后,输入电脑密码就大功告成。

数据库的自动备份,可以减轻维护者的工作量也便于系统恢复,对于比较重要的数据库,最好还是设置下自动备份。

工具/原料



navicat for mysql

mysql 5.5

方法/步骤

  1. 打开navicat客户端,连上mysql后,双击左边你想要备份的数据库。点击“计划”,再点击“新建批处理作业”。


  2. 双击上面的可用任务,它就会到下面的列表里去,代表你选择了这个任务。


  3. 点击保存,弹出个命名对话框,给这个任务取个名字,点击“确定”


  4. 点击“设置”计划任务。


  5. 弹出的对话框,选择“计划”,再点击“新建”。


  6. 这里设置为从2014年1月24号起每天早上九点备份该数据库。如果想提高备份频率、或者设置备份截止日期,请点击“高级”。


  7. 高级选项可以把备份设置的更精细,比如这里设置的是在24小时内每隔2小时就备份一次。加上前面的基本设置,任务计划就是:从2014年1月24号开始,每天九点,每隔2小时备份一次,每天的备份都持续24小时。


  8. 最后,输入电脑密码就大功告成。





windows下:
具体来说,我们若需利用任务计划程序自动运行则应执行如下步骤:

1.单击“开始”按钮,然后依次选择“程序”→“附件”→“系统工具”→“任务计划”(或者是“设置”→“控制面板”→“任务计划”),启动Windows 2000的任务计划管理程序。

2.在“任务计划”窗口中双击“添加任务计划”图标,启动系统的“任务计划向导”,然后单击“下一步”按钮,在给出的程序列表中选择需要自动运行的应用程序,然后单击“下一步”按钮。
设置适当的任务计划名称并选择自动执行这个任务的时间频率(如每天、每星期、每月、一次性、每次启动计算机时、每次登录时等),然后单击“下一步”按钮。
此时系统将会要求用户对程序运行的具体时间进行设置,如几号、几点钟、哪几个时间段才能运行等,我们只需根据自己的需要加以设置即可。

4.接下来系统将会要求用户设置适当的用户名及密码(如图5所示),以便系统今后能自动加以运行。

5.最后,我们只需单击“完成”按钮即可将相应任务添加到Windows 2000的任务计划程序中,此后它就会自动“记住”这个任务,一旦系统时间及相关条件与用户设置的计划相符,它就会自动调用用户所指定的应用程序,十分方便(每次启动Windows 2000的时候,任务计划程序都会自动启动,并在后台运行,确保用户的计划能够按时执行)。

现在我们来测试一下刚才所建的任务是否成功,鼠标右键单击“php”程序图标(如图6所示),在弹出的菜单里面选择“运行”。一般情况下程序图标只要这样激活运行就可以正常启动。如果运行失败可查看用户和密码是否设置正确,还有确定“Task Scheduler”服务是否已启动,本人当初就是为了节省系统资源把它关掉了导致运行失败,害我找了大半天。另外也可从“系统日志”里查看到底是什么原因造成运行失败的。

好了,讲了这么多任务计划的应用,现在我们切入正题,下面将介绍两个例子:

一、让PHP定时运行吧!
1、 编辑如下代码,并保存为test.php:
<?php
$fp = @fopen("test.txt", "a+");
fwrite($fp, date("Y-m-d H:i:s") . " 让PHP定时运行吧!\n");
fclose($fp);
?>

2、添加一个任务计划,在(如图2所示)这一步输入命令:D:\php4\php.exe -q D:\php4\test.php

3、时间设置为每隔1分钟运行一次,然后运行这个任务。

4、现在我们来看看d:\php4\test.txt文件的内容时候是否成功。如果内容为如下所示,那么恭喜你成功了。

2003-03-03 11:08:01 让PHP定时运行吧!
2003-03-03 11:09:02 让PHP定时运行吧!
2003-03-03 11:10:01 让PHP定时运行吧!
2003-03-03 11:11:02 让PHP定时运行吧!

二、让MYSQL实现自动备份变成可能!
1、编辑如下代码,并保存为backup.php,如果要压缩可以拷贝一个rar.exe:
<?php
if ($argc != 2 || in_array($argv[1], array('--help', '-?'))) {
?>
backup Ver 0.01, for Win95/Win98/WinNT/Win2000/WinXP on i32
Copyright (C) 2000 ptker All rights reserved.
This is free software,and you are welcome to modify and redistribute it
under the GPL license

PHP Shell script for the backup MySQL database.

Usage: <?php echo $argv[0]; ?> <option>

<option> can be database name you would like to backup.
With the --help, or -? options, you can get this help and exit.
<?php
} else {
$dbname = $argv[1];
$dump_tool = "c:\\mysql\\bin\\mysqldump";
$rar_tool = "d:\\php4\\rar";
@exec("$dump_tool --opt -u user -ppassword $dbname > ./$dbname.sql");
@exec("$rar_tool a -ag_yyyy_mm_dd_hh_mm $dbname.rar $dbname.sql");
@unlink("$dbname.sql");
echo "Backup complete!";
}
?>

2、添加一个任务计划,在(如图2所示)这一步输入命令:
D:\php4\php.exe -q D:\php4\backup.php databasename
3、时间设置为每天运行一次,然后运行这个任务。
4、最后会在d:\php4\目录下生成一个以数据库名和当前时间组成的rar文件。

linux下:

MySQL :: Linux 下自动备份数据库的 shell 脚本
Linux 服务器上的程序每天都在更新 MySQL 数据库,于是就想起写一个 shell 脚本,结合 crontab,定时备份数据库。其实非常简单,主要就是使用 MySQL 自带的 mysqldump 命令。

脚本内容如下:
#!/bin/sh
# File: /home/mysql/backup.sh
# Database info
DB_NAME="test"
DB_USER="username"
DB_PASS="password"

# Others vars
BIN_DIR="/usr/local/mysql/bin"
BCK_DIR="/home/mysql/backup"
DATE=`date +%F`

# TODO
$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS $DB_NAME | gzip > $BCK_DIR/db_$DATE.gz

然后使用将此脚本加到 /etc/crontab 定时任务中:

01 5 * * 0 mysql /home/mysql/backup.sh

好了,每周日凌晨 5:01 系统就会自动运行 backup.sh 文件备份 MySQL 数据库了。

/home/www/inc/back

直接利用第三方工具“多备份”来实现MySQL自动备份数据库吧,非常方便,可以设置按时/天/周/月/频率进行设置自动增量备份,兼容windows、Linux、Unix等系统,在线就可以一键恢复,不需要写php代码

在LINUX下:
可以写一个shell脚本,由crontab定时调用这个脚本以实现备份数据库。
参考网址:
http://www.baiyuxiong.com/?p=999

数据备份是数据容灾的最后一道防线,即便有着两地三中心的架构,备份也依然重要。如果备份出问题,备份时影响了交易业务,备份数据无法恢复,这些也是企业难以承受的。所以选择合适的备份工具尤为重要。


每个企业级数据库都会有配套的备份工具,MEB(MySQL Enterprise Backup)就是MySQL企业版中非常重要的工具之一,是为企业级客户提供的数据备份方案。


Xtrabackup一直作为MEB 开源版备胎而存在,从MySQL 8.0开始情况可能会变得有所不同。


在 MySQL 8.0的Backup Lock、Redo Log Archiving、Page Tracking等新特性的加持下,MEB备份/恢复体验会更好,目前xtrabackup还不支持这些特性。


MySQL 企业版还有哪些功能?


特性1:Backup Lock


8.0之前使用xtrabackup或MEB做物理备份,为了保证备份时InnoDB引擎表与其他引擎数据文件、及binlog日志的一致性会上全局读锁,再拷贝非InnoDB文件,这期间MySQL会变成只读,数据无法写入。表数量越多,可能加上时间越长,如果使用的xtrabackup 不小心没加rsync参数,逐个拷贝frm文件,锁定时间会更长,对业务影响较大。


我曾遇到过部署在虚拟机的实例有12000多张表,当时使用的xtrabackup,备份脚本中没加rsync参数,结果锁了十几分钟,而MEB就没有这样的问题。


MySQL 8.0支持轻量级备份锁 LOCK INSTANCE FOR BACKUP,数据字典也重构了由InnoDB存储。若不创建非InnoDB表,MEB默认使用备份锁获取binlog日志一致性位置,并阻止DDL操作,但不影响DML操作。


  • 只有InnoDB表,仅上备份锁


  • 请点击输入图片描述

  • 若有非InnoDB表,上全局锁


  • 请点击输入图片描述

    特性2:Redo Log Archiving

    MEB能做到在线热备,备份时不影响数据库读写,这是利用了InnoDB事务日志,在备份期间持续监视redo log的变化,读取增量变化,写入到ibbackup_logfile,也就不需要上锁来保障备份一致性。(对非InnoDB的文件需要上读锁拷贝)

    如果备份期间数据库写入负载特别大,而写入ibbackup_logfile速度较慢,redo log size也不大,很可能会出现ibbackup_logfile的写入速度跟不上redo log记录生成速度,redo log 空间不够时需要覆写日志文件,那么来不及写入ibbackup_logfile的记录会丢失,导致备份失败。

    MEB 4.1对此做了优化,将redo log处理线程拆分成多线程分工合作,提高处理redo log的效率,降低了redo log覆写造成备份失败的概率,但redo log新增速度和ibbackup_logfile写入速度悬殊太大,问题依然会发生。

    MySQL 8.0.17支持了redo log archiving 彻底解决了此问题,备份前设置innodb_redo_log_archive_dirs,指定redo log归档目录。MEB备份时自动开启日志归档,当checkpoint时会将旧记录归档到此目录,后续从归档文件中读取redo日志记录,避免了覆写可能导致的redo记录丢失。


    请点击输入图片描述

    注意:innodb_redo_log_archive_dirs 不能在数据目录下,目录权限要求是700

    特性3:Page Tracking

    Page Tracking 是为优化增量备份效率,减少不必要的数据页扫描。

    增量备份当前有3种扫描模式:

  • page-track:利用LSN精确跟踪上次备份之后被修改页面,仅复制这些页面,效率最快。

  • optimistic:扫描上次备份之后被修改的InnoDB 数据文件中,找出并拷贝修改的页面。依赖系统时间,使用存在限制。

  • full-scan:扫描所有InnoDB数据文件,找出并拷贝自上次备份之后修改的页面,效率最慢

  • 1、利用page-track增量备份,需先安装备份组件

  • mysql> INSTALL COMPONENT "file://component_mysqlbackup";

  • 2、在全备前开启page-track

  • SELECT mysqlbackup_page_track_set(true);

  • 3、全备之后,做增量备份时指定若满足page tracking条件,默认会使用page-track模式,否则会使用full-scan模式,也可以指定--incremental=page-track。

  • mysqlbackup --incremental-backup-dir=backup_incr --trace=3 --incremental=page-track --incremental-base=history:last_full_backup backup

  • incremental-base有3种选择

  • last_backup:基于前一次备份做增备,前一次备份可能是增备,也可能是全备。这种方式全备之间可能会有多个增备,每次增量可能比较小,但恢复时需要逐个合并。

  • last_full_backup:基于前一次全备做增备。这种方式增备会越往后体积可能越大,但恢复时只需要合并最后一次增量备份。

  • dir:基于前一次的备份目录,前一次备份可能是增备,也可能是全备。

  • 测试对比full-scan 和page-track ,在变更页小于总体50%的情况下 ,备份效率至少能有1倍的速度提升。

  • page-track 模式 磁盘读写均衡,说明读写的都是修改页面。

  • 请点击输入图片描述

  • full-scan模式 磁盘读写差别很大,说明读了很多未修改的页面。

  • 请点击输入图片描述




MySQL 该如何自学?
MySQL 是一种关系型数据库管理系统,是最流行的关系型数据库管理系统之一。如果您想自学 MySQL,可以参考以下网站:- 菜鸟教程:提供了 MySQL 的基础教程,适合初学者。- 极客学院:提供了一套通俗易懂的 MySQL 教程,既有基础知识,也有进阶技能。- 慕课网:提供了 MySQL 入门到实战全套教程,适合想深...

请问mysql怎么自动备份数据库?
方法\/步骤 打开navicat客户端,连上mysql后,双击左边你想要备份的数据库。点击“计划”,再点击“新建批处理作业”。双击上面的可用任务,它就会到下面的列表里去,代表你选择了这个任务。点击保存,弹出个命名对话框,给这个任务取个名字,点击“确定”点击“设置”计划任务。弹出的对话框,选择“计划”...

mysql怎么让自增长的
1、创建表时指定AUTO_INCREMENT自增值的初始值(即起始值):CREATE TABLE XXX (ID INT(5) PRIMARY KEY AUTO_INCREMENT) AUTO_INCREMENT=100;2、通过 ALTER TABLE 修改初始值(但是要大于表中的 AUTO_INCREMENT 自增值,否则设置无效):ALTER TABLE XXX AUTO_INCREMENT=100;3、如果自增序列的最大值被...

mysql怎么设置自动编号呢?
1、单击“保存更改”按钮。2、验证成功,输入 show create database day15; 点击回车(day15为数据库名称)。3、在下方的信息栏即可看到当前查询数据库编码信息。4、 如果需要修改编码信息,可以输入alter database day15 default character set gbk; 点击回车即可。5、打开第三方的数据库管理软件,找到...

Mysql 开机自启动怎么设置
服务的话它是按字母排列的,我们往下拉,找到Mysql服务。此时可以看到它是一个手动启动的状态。请点击输入图片描述 请点击输入图片描述 在mysql服务上点击鼠标右键,选择属性。请点击输入图片描述 请点击输入图片描述 然后跳出的如下图的界面中我们将手动改成自动,点击确定,这样你的mysql服备就是一个自...

mysql如何设置ID自增
MYSQL的自增列一定要是有索引的列,设置种子值要在表的后面设置 --mysql -- 设置自增ID从N开始 CREATE TABLE empautoinc(ID INT PRIMARY KEY AUTO_INCREMENT ) AUTO_INCREMENT = 100 ; --(设置自增ID从100开始)insert into empautoinc(id) values(null);Query OK, 1 row affected (0.00 ...

mysql自动增长主键怎么设置?
先双击拉出TABLE,在TABLE上右键创建新表。解决方案:将主键设置为自动增长。可以在数据库手动将相关表设置ID为自增长 手动将表设置为自增长有弊端,建议在annotation里边的POJO类使用注解方式设置自增长。mysql的数据库如图所示设置。保存执行即可解决问题 查看数据库,果然自增了 ...

mysql 的自增主键是如何实现的?
MySQL 的自增主键是通过 auto_increment 属性实现的。在创建表时,可以使用 auto_increment 关键字来指定自增的列,并指定自增列的初始值为 1。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。

如何实现Mysql数据库每天自动备份定时备份
利用UCache灾备云平台,可作为一个工具,在window服务器现有架构不变的情况下,针对Mysql数据库每天自动备份定时备份。 (1)新建备份任务 UCACHE灾备云控制台登录账号后:点击【服务器定时数据保护】--【数据备份】点击【新建】按钮,然后选要保护的对象(您的生产服务器节点),选中对应的客户端,选择【文件系统】然后点击【 ...

mysql数据库怎么让id自动增长,但ID不是主键。难道只有ID为主键时,才...
从零蛋娃娃的回复中得到启示,解决问题。重新表述需求: id自增长,同时需要一个键uniquekey是唯一键。解决方法就是:把id在索引中设置索引类型为任意一个类型,比如normal,然后unique就可以设置为主键了。或者反过来,id自增长,同时作为主键。 uniquekey在索引中索引类型设置为unique即可。补充:考虑到主键...

肥西县15957122130: 如何设置mysql自动备份数据库 -
厨人诞丙克: 使用navicat工具连接mysql数据库,这里以navicat for Mysql工具为例.如果数据库在本机,那么连接ip处写localhost即可,如果数据库在其他机器,那需要写具体的ip地址.设置mysql备份文件的存储路径.新建连接页面,设置连接信息的右侧有...

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

肥西县15957122130: 如何实现MySQL的自动备份 -
厨人诞丙克: MySql自动备份是非常关键的,特别是对于DBA来说.这里主要用代码来说明这个问题,希望对各位有所帮助.可以将这个脚本放进crontab,每天凌晨执行一次,自动备份.这个脚本每天最多只执行一次,而且只保留最近五天的备份在服务器上...

肥西县15957122130: 请问达人mysql数据库如何实现定时自动备份 -
厨人诞丙克: 补充一下,不能停机,最好能够加一个read锁,备份完以后释放.

肥西县15957122130: MYSQL数据如何实时备份 -
厨人诞丙克: MYSQL数据如何实时备份 依次单击:开始--程序--Microsoft SQL Server--企业管理器--SQL Server组--管理--数据库维护计划 在右侧空白处右键单击,新建维护计划--勾选要备份的数据库--下一步 指定数据库备份计划--调度--单击"更改"--设置备...

肥西县15957122130: 怎么定时自动备份mysql数据表 -
厨人诞丙克: 一、对于Windows主机============== 假想环境:MySQL 安装位置:C:\MySQL 论坛数据库名称为:bbs MySQL root 密码:123456 数据库备份目的地:D:\db_backup\ @echo off C:\MySQL\bin\mysqladmin -u root –password=...

肥西县15957122130: 如何让定时备份mysql数据库 -
厨人诞丙克: 第一种:新建批处理文件 backup.dat,里面输入以下代码:net stop mysql xcopy "C:\Program Files\MySQL\MySQL Server 5.0\data\piaoyi\*.*" D:\db_backup\%date:~0,10%\ /y net start mysql 第二种:mysqldump备份成sql文件============== ...

肥西县15957122130: mysql定时备份怎么操作 -
厨人诞丙克: linux下为例:写个脚本:1 mysqldump -u用户名 -p密码 数据库名 > /路径/文件前缀$(date+%Y%m%d).sql 然后crontab里设置运行时间就行.windows的话类似,但是要放到定时任务里.

肥西县15957122130: 如何定时对mysql数据库备份 -
厨人诞丙克: 这个方法是用bat批处理来完成的.假想环境:MySQL 安装位置:D:\Program Files\MySQL\MySQL Server 5.0\data 数据库名称为:952game数据库备份目的地:d:\db_bak\ (你想把数据库备份到哪个盘的路径)我想备到D盘的db-bak目录下面=...

肥西县15957122130: 怎么用navicat自动备份mysql数据库 -
厨人诞丙克: 数据库的自动备份,可以减轻维护者的工作量也便于系统恢复,对于比较重要的数据库,最好还是设置下自动备份:打开navicat客户端,连上mysql后,双击左边你想要备份的数据库.点击“计划”,再点击“新建批处理作业”.双击上面的...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网