CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中
一、安装Email发送程序
yuminstallsendmailmutt
二、安装FTP客户端程序
本脚本需要用到FTP客户端程序将文件上传到FTP空间上面,因此必须安装FTP客户端,否则将出现ftp命令无法找到的错误。
安装步骤请参考:《CentOS提示ftp:commandnotfound》
三、在/root目录下新建脚本文件:AutoBackupToFtp.sh,内容如下:
#!/bin/bash #你要修改的地方从这里开始 MYSQL_USER=root #mysql用户名 MYSQL_PASS=123456 #mysql密码 MAIL_TO=xxxxx@gmail.com #数据库发送到的邮箱 FTP_USER=ftpuser #ftp用户名 FTP_PASS=ftpuserpassword #ftp密码 FTP_IP=xxx.xxx.xxx.xxx #ftp地址 FTP_backup=backup #ftp上存放备份文件的目录,这个要自己得ftp上面建的 WEB_DATA=/home/wwwroot #要备份的网站数据,如果是使用lnmp安装包,则默认这个为网站目录 #你要修改的地方从这里结束
#定义数据库的名字和旧数据库的名字 DataBakName=Data_$(date+"%Y%m%d").tar.gz WebBakName=Web_$(date+%Y%m%d).tar.gz OldData=Data_$(date-d-5day+"%Y%m%d").tar.gz OldWeb=Web_$(date-d-5day+"%Y%m%d").tar.gz #删除本地3天前的数据 rm-rf/home/backup/Data_$(date-d-3day+"%Y%m%d").tar.gz/home/backup/Web_$(date-d-3day+"%Y%m%d").tar.gz cd/home/backup #导出数据库,一个数据库一个压缩文件 fordbin`/usr/local/mysql/bin/mysql-u$MYSQL_USER-p$MYSQL_PASS-B-N-e'SHOWDATABASES'|xargs`;do (/usr/local/mysql/bin/mysqldump-u$MYSQL_USER-p$MYSQL_PASS${db}|gzip-9->${db}.sql.gz) done #压缩数据库文件为一个文件 tarzcf/home/backup/$DataBakName/home/backup/*.sql.gz rm-rf/home/backup/*.sql.gz #发送数据库到Email,如果数据库压缩后太大,请注释这行 echo"Content:Thisemailisautosendbyvps..."|mutt-a/home/backup/$DataBakName-s"Subject:VPSDatabaseBackup"$MAIL_TO #压缩网站数据 tarzcf/home/backup/$WebBakName$WEB_DATA #上传到FTP空间,删除FTP空间5天前的数据 ftp-v-n$FTP_IP<<END user$FTP_USER$FTP_PASS typebinary cd$FTP_backup delete$OldData delete$OldWeb put$DataBakName put$WebBakName bye END