mysql 备份shell?请问mysql怎么自动备份数据库
一、如何每天自动备份MySql文件
随着数据库在网站建设中的不断应用,现如今绝大多数网站已经离不开数据库支持了,因为数据库不仅可以存储网站内容等信息,还可以存储用户提交的信息。由于这些信息非常宝贵,一旦丢失几乎难以挽回。
所有站长不仅要注意备份服务器上的网页html文件,图片或者程序代码,还要对数据库文件优先进行备份。
最简单的数据库备份可以通过phpMyAdmin手动备份并下载文件到指定位置,但是对于那些需要每天及时备份的站长来说,手动备份数据库比较麻烦,所以本文讲解一下如何利用国外主机的时钟程序配合shell命令代码实现每天定时备份数据库文件并下载到指定目录。
shell备份数据库
首先创建一个文件命名为:“backup.sh”,在其中输入以下命令:
#!/bin/bash
# Set a value that we can use for a datestamp
DATE=`date+%Y-%m-%d`$
# Our Base backup directory
BASEBACKUP="/backup/daily"
for DATABASE in `cat/backup/db-list.txt`
do
# This is where we throw our backups.
FILEDIR="$BASEBACKUP/$DATABASE"
# Test to see if our backup directory exists.
# If not, create it.
if [!-d$FILEDIR ]
then
mkdir-p$FILEDIR
fi
echo-n"Exporting database:$DATABASE"
mysqldump--user=root--opt$DATABASE| gzip-c-9>$FILEDIR/$DATABASE-$DATE.sql.gz
echo"......[ Done Exporting to local backup, now exporting for remote backup]"
cp$FILEDIR/$DATABASE-$DATE.sql.gz/backup/uploads/$DATABASE.sql.gz
echo".......[Done]"
done
# AutoPrune our backups. This will find all files
# that are"MaxFileAge" days old and delete them.
MaxFileAge=4
find$BASEBACKUP-name'*.gz'-type f-mtime+$MaxFileAge-exec rm-f{}\;
简单来说,这个命令会从db-list.txt文件(一个记录有数据库名称的列表文本文件)中逐行调取数据库并输出+压缩数据文件(datastamped)到/backup/daily/databasename/目录下面;然后该命令有把一个 non-datestamped文件存储到/backup/uploads/目录下面,并覆盖掉原有的文件。
同时,为了节约资源,该命令会自动删掉4天前的数据库文件。
时钟命令(Cron Jobs)
备份完之后要利用时钟命令将数据库备份以及存储以自动的方式每天执行,首先需要激活backup.sh;
10 4*** sh/ backup/backup.sh
这个命令是让服务器每天早上4:10分开始执行数据库备份,当然什么时间执行是取决你的。
然后在时钟命令中输入以下命令:
10 6***/usr/local/bin/ncftpput-Ef/home/admin/ncftpputlogin//backup/uploads/*
这个命令是告诉一个命名为ncftpput的程序(该程序位于ncftputlogin目录下)每天早上6:10将数据库文件上传到/backup/uploads目录下面。ncftpputlogin目录中存有服务器的用户信息,如果你的服务器没有安装ncftp,你可以自己安装一个,很简单。
总结
如果你的数据库文件较大,可能备份的时候需要占用很多服务器资源,所以站长要尽量选择访客最少的时间段执行自动备份命令,比如凌晨4-5点左右。而且要注意给备份留下足够的时间然后执行存储命令。
因为一个服务器可能会遭到天灾人祸,备份的数据库文件要存在不同的服务器或者下载到本地更保险。
二、Linux下mysql数据库备份方法
通过mysql提供的功能
导出
命令:
mysqldump-u用户名-p数据库数据库.sql
示例:
代码如下 复制代码
mysqldump-u root-p db1 db1.sql(将数据库db1备份到db1.sql中)
提示输入密码,完成即可。
导入
需要先创建一个空数据库
mysql-u root-p(输入密码后进入mysql)
create database db1;(创建一个名为db1的数据库)
exit(退出mysql)
命令:
mysql-u用户名-p数据库数据库.sql
示例:
代码如下 复制代码
mysql-u root-p db1 db1.sql(从备份文件db1.sql中导入数据到数据库db1中)
提示输入密码,完成即可。
通过拷贝文件
如果数据库特别大,可以使用拷贝的方式进行备份,不过不同的操作系统间可能会导致不兼容。
导出
进入mysql目录,打包需要备份的数据库目录
示例:
代码如下 复制代码
cd/var/lib/mysql(进入mysql目录)
tar-zcvf db1.tar.gz db1(打包db1目录,如果提示没有权限,在前面加上sudo,提示输入密码后即可)
导入
首先创建一个空数据库,将打包的文件拷贝到mysql目录后解压
示例:
代码如下 复制代码
mysql-u root-p(输入密码后进入mysql)
create database db1;(创建一个名为db1的数据库)
exit(退出mysql)
cp db1.tar.gz/var/lib/mysql(将打包文件拷贝到mysql目录下)
cd/var/lib/mysql(进入mysql目录)
tar-zxvf db1.tar.gz(解压到当前目录)
后现在linux中脚本
代码如下 复制代码
#!/bin/bash
#Mysql autobackup shell#write by tuspark.cn
#-------------------数据库相关的用户名、密码、需要备份的数据库名、备份目录等
dbuser=root
dbpasswd=XXXXX
dbserver=localhost
dbname=XXXXX
dbopt=--opt
backupdir=/dcbackup/
#-------------------是否开启FTP远程备份,0为否,1为是。
copytoftp=1
ftpserver=XXXXX
ftpuser=XXXXX
ftppasswd=XXXXX
#-------------------以下参数
fileprefix=dcradiusdump
filename=$backupdir`date+%F`.sql
newfile=$fileprefix-`date+%F`.tar.gz
keepdays=10
#-------------------以下为备份时的日志
logfile=/var/log/mysqlbackup.log
logtmp=/var/log/mybackup.tmp
#===============================================
if [!-d$backupdir ]
then
echo"$backupdir is not exist, then make..."$logfile
mkdir-p$backupdir
fi
echo"start===================================="$logfile
echo"Beginning backup `date'+%F%T'`"$logfile
echo"Delete$keepdays days ago files..."$logfile
find$backupdir-name$fileprefix*-mtime+$keepdays-fls$logtmp-exec rm{};
echo"Deleted Backup file is:"$logfile
cat$logtmp$logfile
echo"Delete old file Success!"$logfile
if [-f$backupdir$newfile ]
then
echo"$newfile backup exist, backup stop..."$logfile
else
if [-z$dbpasswd ]
then
mysqldump-u$dbuser-h$dbserver$dbopt$dbname$dumpfilename
else
mysqldump-u$dbuser-p$dbpasswd-h$dbserver$dbopt$dbname$dumpfilename
fi
tar czvf$backupdir$newfile$dumpfilename$logfile 21
echo"$backupdir$newfile Backup Success!"$logfile
rm-fr$dumpfilename
if [$copytoftp= 1 ]; then
if [-z$ftpserver ];then
echo"Ftp Server not set,Copy to Ftp Failed..."$logfile
exit 1
elif [-z$ftpuser ];then
echo"Ftp user not set, Copy to Ftp Failed..."$logfile
exit 2
elif [-z$ftppasswd ]; then
echo"Ftp password not set, Copy to Ftp Failed..."$logfile
exit 3
else
echo"Start copy to Ftp server...."$logfile
ftp-n$logfile
fi
三、请问mysql怎么自动备份数据库
数据库的自动备份,可以减轻维护者的工作量也便于系统恢复,对于比较重要的数据库,最好还是设置下自动备份。
工具/原料
navicat for mysql
mysql 5.5
方法/步骤
打开navicat客户端,连上mysql后,双击左边你想要备份的数据库。点击“计划”,再点击“新建批处理作业”。
双击上面的可用任务,它就会到下面的列表里去,代表你选择了这个任务。
点击保存,弹出个命名对话框,给这个任务取个名字,点击“确定”
点击“设置”计划任务。
弹出的对话框,选择“计划”,再点击“新建”。
这里设置为从2014年1月24号起每天早上九点备份该数据库。如果想提高备份频率、或者设置备份截止日期,请点击“高级”。
高级选项可以把备份设置的更精细,比如这里设置的是在24小时内每隔2小时就备份一次。加上前面的基本设置,任务计划就是:从2014年1月24号开始,每天九点,每隔2小时备份一次,每天的备份都持续24小时。
最后,输入电脑密码就大功告成。