#!/bin/bash #需要修改的地方从这里开始 WEB_DATA=/home/wwwroot #要备份的网站数据 nginx_DATA=/usr/local/nginx/conf #要备份的NGINX配置文件 PHP_Config=/usr/local/php/etc #要备份的PHP配置文件 Ftp=/usr/local/pureftpd #要备份的PURE-FTPD Folder=/home/bak #备份文件的存放文件夹 Config=/etc/init.d/ #要备份的服务文件 ppp=/etc/ppp #要备份的PPP(pptp)账号数据 date=$(date +"%Y%m%d") #今日时间 MYSQL_UserName=root #mysql账号 MYSQL_PassWord=password #mysql密码 DB_Name1=test1 #数据库1 DB_Name2=test2 #数据库2 DB_Name3=test3 #数据库3 DB_Name4=test4 #数据库4 默认是四个数据库,按自己情况增加减少 #需要修改的地方从这里结束 #手动备份删除今日数据 rm -fr /$Folder/$date.tar.gz #删除3天前的数据 rm -fr /$Folder/$(date -d -3day +"%Y%m%d").tar.gz #创建今天的备份目录 mkdir -p /$Folder/$date #压缩网站数据 cd $WEB_DATA tar zcf /$Folder/$date/web.tar.gz ./* #备份并压缩Mysql数据库 /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $DB_Name1 > /$Folder/$date/$DB_Name1-$(date +"%Y%m%d").sql /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $DB_Name2 > /$Folder/$date/$DB_Name2-$(date +"%Y%m%d").sql /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $DB_Name3 > /$Folder/$date/$DB_Name3-$(date +"%Y%m%d").sql /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $DB_Name4 > /$Folder/$date/$DB_Name4-$(date +"%Y%m%d").sql cd $Folder tar zcf /$Folder/$date/database-$(date +"%Y%m%d").tar.gz ./$date/*.sql #备份NGINX配置文件 cd $nginx_DATA tar zcf /$Folder/$date/nginx.tar.gz ./* #备份PHP配置文件 cd $PHP_Config tar zcf /$Folder/$date/php.tar.gz ./* #压缩FTP Server文件 cd $Ftp tar zcf /$Folder/$date/ftp.tar.gz ./* #压缩服务文件 cd $Config tar zcf /$Folder/$date/d.tar.gz ./nginx ./mysql ./php-fpm ./ftpd #打包PPP配置以及PPTP拨号帐号 cd $ppp tar zcf /$Folder/$date/ppp.tar.gz ./* #备份SSHD配置文件 cp /etc/ssh/sshd_config /$Folder/$date #备份crontab内容 crontab -l > /$Folder/$date/crontab_$date.txt #压缩当天数据 cd /$Folder/ tar zcf /$Folder/$date.tar.gz ./$date/* #删除当天备份文件夹 rm -fr /$Folder/$date