找回密码
 注册
广告投放 虚位以待【阿里云】2核2G云新老同享 99元/年,续费同价做网站就用糖果主机-sugarhosts.comJtti.com-新加坡服务器,美国服务器,香港服务器
查看: 639|回复: 0

自动备份网站文件和数据库上传到FTP空间

[复制链接]
发表于 2010 年 10 月 2 日 18:24:41 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

×

主要功能: 自动备份网站文件和数据库并上传到FTP空间,在本地保留3天备份,在远端FTP空间保留5天备份.
数据库备份采用发送到Email和FTP空间,双重备份,保证数据的安全.
首先安装Email发送组件代码:

  1. yum install sendmail mutt
复制代码

脚本如下:

  1. #!/bin/bash
    cd /home/backup
    #定义数据库的名字和旧数据库的名字
    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
    #导出mysql数据库
    /usr/local/mysql/bin/mysqldump -uroot -p123456 --databases db1 db2 db3 > /home/backup/databackup.sql
    #压缩数据库
    tar zcf /home/backup/$DataBakName /home/backup/databackup.sql
    rm -rf /home/backup/databackup.sql
    #发送数据库到Email,假设数据库压缩后太大,请注释这行
    echo "主题:数据库备份" | mutt -a /home/backup/$DataBakName -s "内容:数据库备份" www@gmail.com
    #压缩网站数据
    tar zcvf /home/backup/$WebBakName /home/www
    #上传到FTP空间,删除FTP空间5天前的数据
    ftp -v -n imcat.in << END
    user imcat 123456
    type binary
    cd backup
    delete $OldData
    delete $OldWeb
    put $DataBakName
    put $WebBakName
    bye
    END
复制代码

下载地址:http://deak17.googlecode.com/files/AutoBackupToFtp.sh
下载脚本,给脚本添加权限:

  1. chmod +x AutoBackupToFtp.sh
复制代码

利用crontab 实现自动备份,在ssh下,

  1. crontab -e
复制代码

没有这个命令?请看CentOS安装crontab及使用方法
输入以下内容:

  1. 00 00 * * * /home/AutoBackupToFtp.sh
复制代码

这样就实现了每天00:00自动备份网站文件和数据库上传到FTP空间



Jgwy.Com - Free Web Hosting Guide & Directory In China since 2001! Jgwy.Net-Jglt.Net
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|金光论坛

GMT+8, 2025 年 2 月 3 日 12:39 , Processed in 0.025809 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表