Linux VPS/服务器 网站及数据库自动本地备份并FTP上传备份脚本
从VPS侦探建站之初就一直在重申一定要备份好自己的数据,因为太多的不确定性可能会造成数据库丢失,而且大部分VPS服务商也不可能提供每天备份数据。
原来VPS侦探提供过一个VPS备份方法,只是略微说了一下,可能部分新手会不太好入手。今天VPS侦探分享一个自己的备份脚本。
准备工作:
需要提前在VPS安装好lftp,lftp功能上比较强大,CentOS直接执行:yum install lftp,Debian执行:apt-get install lftp 。
需要在VPS上创建/home/backup/ 目录,在FTP上创建backup目录。
如果VPS上数据库不多的话使用Godaddy的免费空间就可以(10GB空间,300GB流量),只要注册个域名就免费送。
下面将备份脚本进行部分注释:
#!/bin/bash
#Funciont: Backup website and mysql database
#Author: licess
#Website: https://lnmp.org
#IMPORTANT!!!Please Setting the following Values!
######~Set Directory you want to backup~######将下面的目录修改成自己要备份的目录,一般按我的都是在/home/wwwroot/下面所有直接写了需要备份的目录。可以继续再加:Backup_Dir5=你的目录 ,Backup_Dir后面的数字依次递增。如果不足4个,直接删除不需要的就可以,同时修改下面tar zcf 部分。
Backup_Dir1=vpser.net
Backup_Dir2=lnmp.org
Backup_Dir3=licess.org
Backup_Dir4=jungehost.com
######~Set MySQL UserName and password~######设置MySQL的用户名和密码,最好是root,其他用户可能因为权限问题无法导出部分数据库。
MYSQL_UserName=root
MYSQL_PassWord=yourmysqlrootpassword
######~Set MySQL Database you want to backup~######设置要部分的数据库,可以继续再加:Backup_Database_Name5=数据库名,Backup_Database_Name后面的数字依次递增。
Backup_Database_Name1=vpser
Backup_Database_Name2=licess
Backup_Database_Name3=junge
Backup_Database_Name4=vpserorg
######~Set FTP Information~######设置用来存放备份数据的FTP信息
FTP_HostName=184.168.192.43 //FTP服务器的IP或者域名
FTP_UserName=vpsernet //FTP服务器用户名
FTP_PassWord=yourftppassword //FTP服务器用户对应的密码
FTP_BackupDir=backup //备份到FTP上的目录,需要提前创建好。
#Values Setting END!
TodayWWWBackup=www-*-$(date +"%Y%m%d").tar.gz
TodayDBBackup=db-*-$(date +"%Y%m%d").sql
OldWWWBackup=www-*-$(date -d -3day +"%Y%m%d").tar.gz
OldDBBackup=db-*-$(date -d -3day +"%Y%m%d").sql
tar zcf /home/backup/www-$Backup_Dir1-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir1 --exclude=soft
tar zcf /home/backup/www-$Backup_Dir2-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir2
tar zcf /home/backup/www-$Backup_Dir3-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir3 --exclude=test
tar zcf /home/backup/www-$Backup_Dir4-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir4
###上面为备份网站文件数据,因为我的网站比较零散,而且网站目录下面有些目录属于临时目录并不需要备份,所以可以在上面加上--exclude=不备份的目录。如果在前面加了Backup_Dir5=yourdir,则再加tar zcf /home/backup/www-$Backup_Dir5-$(date +"%Y%m%d").tar.gz -C
/home/wwwroot/ $Backup_Dir5 。如果多余则删除多余行。
/usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name1 > /home/backup/db-$Backup_Database_Name1-$(date +"%Y%m%d").sql
/usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name2 > /home/backup/db-$Backup_Database_Name2-$(date +"%Y%m%d").sql
/usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name3 > /home/backup/db-$Backup_Database_Name3-$(date +"%Y%m%d").sql
/usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name4 > /home/backup/db-$Backup_Database_Name4-$(date +"%Y%m%d").sql
###上面为备份MySQL数据库,如果在前面加了Backup_Database_Name5=yourdatabasename,则再加/usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name5 > /home/backup/db-$Backup_Database_Name5-$(date +"%Y%m%d").sql 。如果多余则删除多余行。
rm $OldWWWBackup
rm $OldDBBackup
###删除3天前的备份###
cd /home/backup/
###下面为自动上传部分,不得不说lftp很强大,抛弃ftp吧####
lftp $FTP_HostName -u $FTP_UserName,$FTP_PassWord << EOF
cd $FTP_BackupDir
mrm $OldWWWBackup
mrm $OldDBBackup
mput $TodayWWWBackup
mput $TodayDBBackup
bye
EOF
脚本下载地址:http://soft.vpser.net/lnmp/backup.sh
下载脚本,将脚本放到/root/ 下面,按上面的注释修改脚本中的参数,并保存,如果不熟悉vi或者nano编辑器,可以用winscp,执行:chmod +x /root/backup.sh 为脚本添加执行权限,执行:crontab -e 添加定时执行
在crontab中加入:0 3 * * * /root/backup.sh
凌晨3点自动执行/root/bakcup.sh 脚本,备份vps上的数据并上传到FTP上。
如果在使用过程中有任何问题请直接留言,或到VPS论坛发贴。原创文章,禁止转载!
>>转载请注明出处:VPS侦探 本文链接地址:https://www.vpser.net/security/linux-autobackup-ftp.html
建议把数据文件也压缩下,能减小不少体积,节省上传时间。
压缩:gzip > /home/backup/backupfile.sql.gz
导入:gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename
送上一个我的脚本,你这个复杂了点!!
#!/bin/bash
# Author: Jalena
# Website: //jalena.bcsytv.com/archives/1099
# function
MYSQL_USER="root"
MYSQL_PASS="******" #mysql密码
BACK_DIR="backup"
# Create backup directory
if [ -d $BACK_DIR ] ;
then
rm -rf ~/$BACK_DIR/*
else
mkdir -p "$BACK_DIR"
fi
# Enter the backup directory
cd $BACK_DIR
# Backup all database tables
for db in $(mysql -u$MYSQL_USER -p$MYSQL_PASS -B -N -e 'SHOW DATABASES' |sed -e '/schema/d' -e '/mysql/d')
do
mysqldump -u$MYSQL_USER -p$MYSQL_PASS ${db} | gzip -9 - > ${db}.sql.gz
done
# Pack all database tables
tar -zcf mysql_$(date +%Y%m%d).tar.gz *.sql.gz --remove-files
# Packing site data
for web in $(ls -1 /home/wwwroot |sed -e '/php/d')
do
tar -zcPf ${web}_$(date +%Y%m%d).tar.gz /home/wwwroot/$web/
done
# Package the Nginx configuration file
tar -zcPf nginx_$(date +%Y%m%d).tar.gz /usr/local/nginx/conf/vhost
# Upload data
for file in $(find *.tar.gz | grep $)
do
# scp -P 22 ${file} 123.456.789.012:/root/backup/${file}
sh ~/dropbox_uploader.sh upload ${file} $(date +%Y%m%d)/${file}
done
exit 0
问题解决了,使用crontab要注意时差,以服务器为准,用国外VPS的要注意!
为什么我一台VPS上都成功了,但在Linode上就不行呢。手动执行/root/backup.sh都能备份并传到ftp,但加入crontab中就不会自动执行。服务是启动的,不存在权限问题,因为手动执行都能成功。
@sr, 修改/etc/lftp.conf
添加上set xfer:clobber on试试
脚本挺好的,就是mput的时候偶尔会中断,网站文件没传完就开始传数据库了,我尝试过加 -c 断点续传,但无效果,这个怎么解决呢?
@peter, 确认该ip的ftp服务是否开启
@VPSer
lftp连接后会超时,比如lftp ip -u root,passwd
ip[连接超时:40]
@peter, 加上参数--single-transaction 试试
@peter, 执行完一个再执行
@peter, 临时切换目录
mysqldump: Got error: 1044: Access denied for user 'root'@'localhost' to database 'db' when using LOCK TABLES
shell脚本的执行流程是啥呢?
比如tar zcf /data/backup/$Backup_Dir2-$(date +"%Y%m%d")bak.tar.gz -C /data/wwwroot/ $Backup_Dir2,这个命令执行时需要时间的,正常是全部备份完成才到下一条执行命令吗?
因为如果不是这样的话,在执行lftp的时候逻辑是不合适的。
tar 的-C参可以讲解下,一般人不明白啥意思。
tar zcf /data/backup/$Backup_Dir2-$(date +"%Y%m%d")bak.tar.gz -C /data/wwwroot/ $Backup_Dir2
-C是指切换当前命令的工作目录,上面的意思是切当前的工作目录为/data/wwwroot/,将其下的$Backup_Dir2文件,压缩到目录文件。
@peter, 着2个是一种方法
貌似这一种更简单http://www.vpser.net/security/vps-backup-web-mysql.html,如果有这种方法有限制没, 比如数据的存储引擎、数据很大时?