Welcome 微信登录

首页 / 数据库 / MySQL / 使用mysqlhotcopy备份MySQL

我以前备份都使用mysqldump,导成文本文件便于存放,但是速度很慢的。最快的备份方法当然是直接把数据目录copy一份了。但是一般来说,都要关闭 MySQL的服务才能做,不然在你copy的时候刚好还有人读写表那麻烦就大了。这次朋友介绍我使用mysqlhotcopy。就相当于上面,不过他可以热备份.他备份非常快,我测试一个2.8G的mysql他备份的时间在3分钟内完成.下面是它的介绍.mysqlhotcopy是一个Perl脚本,最初由Tim Bunce编写并提供。它使用LOCK TABLES、FLUSH TABLES和cp或scp来快速备份数据库。它是备份数据库或单个表的最快的途径,但它只能运行在数据库目录所在的机器上。mysqlhotcopy只用于备份MyISAM。它运行在Unix和NetWare中使用方法见下面的脚本.加入crotab中吧.#!/bin/sh# Name:mysqlbackup.sh# PS:MySQL DataBase Backup,Use mysqlhotcopy script.# Last Modify:2008-06-12# 定义变量,请根据具体情况修改# 定义脚本所在目录scriptsDir=`pwd`# 数据库的数据目录dataDir=/var/lib/mysql# 数据备份目录tmpBackupDir=/tmp/mysqlblackupbackupDir=/backup/mysql# 用来备份数据库的用户名和密码mysqlUser=rootmysqlPWD="you password"# 如果临时备份目录存在,清空它,如果不存在则创建它if [[ -e $tmpBackupDir ]]; thenrm -rf $tmpBackupDir/*elsemkdir $tmpBackupDirfi# 如果备份目录不存在则创建它if [[ ! -e $backupDir ]];thenmkdir $backupDirfi# 得到数据库备份列表,在此可以过滤不想备份的数据库for databases in `find $dataDir -type d | sed -e "s//var/lib/mysql///" | sed -e "s/test//"`; doif [[ $databases == "" ]]; thencontinueelse# 备份数据库/usr/bin/mysqlhotcopy --user=$mysqlUser --password=$mysqlPWD -q "$databases" $tmpBackupDirdateTime=`date "+%Y.%m.%d %H:%M:%S"`echo "$dateTime Database:$databases backup success!" >>MySQLBackup.logfidone# 压缩备份文件date=`date -I`cd $tmpBackupDirtar czf $backupDir/mysql-$date.tar.gz ./#End完成加入到crontab中设置每周5运行0 0 * * 5 /backup/blackup.sh注意:恢复数据库到备份时的状态
  • 1
  • 2
  • 下一页
Ubuntu 8.04 Desktop 版的MySQL BUG?Linux 下 MySQL初级知识相关资讯      MySQL教程 
  • 30分钟带你快速入门MySQL教程  (02月03日)
  • MySQL教程:关于I/O内存方面的一些  (01月24日)
  • CentOS上开启MySQL远程访问权限  (01/29/2013 10:58:40)
  • MySQL教程:关于checkpoint机制  (01月24日)
  • MySQL::Sandbox  (04/14/2013 08:03:38)
  • 生产环境MySQL 5.5.x单机多实例配  (11/02/2012 21:02:36)
本文评论 查看全部评论 (0)
表情: 姓名: 字数