CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中

 更新时间:2014年12月23日 09:02:13   投稿:junjie  
这篇文章主要介绍了CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中,本文脚本比较实用,其它Linux系统也可参考,需要的朋友可以参考下

一、安装Email发送程序


复制代码 代码如下:

yum install sendmail mutt

二、安装FTP客户端程序

本脚本需要用到FTP客户端程序将文件上传到FTP空间上面,因此必须安装FTP客户端,否则将出现ftp命令无法找到的错误。
安装步骤请参考:《CentOS提示ftp:command not found

三、在/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
#导出数据库,一个数据库一个压缩文件
for db in `/usr/local/mysql/bin/mysql -u$MYSQL_USER -p$MYSQL_PASS -B -N -e 'SHOW DATABASES' | xargs`; do
    (/usr/local/mysql/bin/mysqldump -u$MYSQL_USER -p$MYSQL_PASS ${db} | gzip -9 - > ${db}.sql.gz)
done
#压缩数据库文件为一个文件
tar zcf /home/backup/$DataBakName /home/backup/*.sql.gz
rm -rf /home/backup/*.sql.gz
#发送数据库到Email,如果数据库压缩后太大,请注释这行
echo "Content:This email is auto send by vps..." | mutt -a /home/backup/$DataBakName -s "Subject:VPS Database Backup" $MAIL_TO
#压缩网站数据
tar zcf /home/backup/$WebBakName $WEB_DATA
#上传到FTP空间,删除FTP空间5天前的数据
ftp -v -n $FTP_IP << END
user $FTP_USER $FTP_PASS
type binary
cd $FTP_backup
delete $OldData
delete $OldWeb
put $DataBakName
put $WebBakName
bye
END

四、配置

给脚本添加执行权限:

复制代码 代码如下:

chmod 774 /root/AutoBackupToFtp.sh

利用系统crontab实现每天自动运行:

复制代码 代码如下:

crontab -e

输入以下内容:

复制代码 代码如下:

00 02 * * * /root/AutoBackupToFtp.sh

其中00 02为时间分/小时,可自行修改,例如:30 12 ***,就是每天12.30运行这个脚本。

相关文章

  • Shell 批量进程判断是否存在

    Shell 批量进程判断是否存在

    本文主要介绍了Shell 批量进程判断是否存在,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Shell脚本监控服务器在线状态和邮件报警的方法

    Shell脚本监控服务器在线状态和邮件报警的方法

    这篇文章主要介绍了Shell脚本监控服务器在线状态和邮件报警的方法,使用的是ping命令来监控,需要的朋友可以参考下
    2014-03-03
  • Linux启动与自启动的实例详解

    Linux启动与自启动的实例详解

    这篇文章主要介绍了Linux启动与自启动的实例详解的相关资料,希望通过本文大家能理解掌握这部分内容,需要的朋友可以参考下
    2017-09-09
  • Linux 中ls命令的使用详细介绍

    Linux 中ls命令的使用详细介绍

    本文是小编整理的ls命令的基本使用方式,文中示例中的命令选项都可以进行任意组合来使用,比如倒序排序使用"ls -rs"命令等,对Linux 中ls命令用法感兴趣的朋友一起看看吧
    2022-06-06
  • Shell编程控制结构的基本使用

    Shell编程控制结构的基本使用

    本文主要介绍了Shell编程控制结构的基本使用,主要介绍了几种常用的控制语句,具有一定的参考价值,感兴趣的可以了解一下
    2021-11-11
  • Linux下Oracle归档日志自动清理脚本代码(sh)

    Linux下Oracle归档日志自动清理脚本代码(sh)

    将以下代码保存为.sh文件,并放到crontab里就可以实现自动清理
    2013-01-01
  • linux系统mysql自动备份并使用ftp上传的方法

    linux系统mysql自动备份并使用ftp上传的方法

    这篇文章主要介绍了linux系统自动导出mysql备份,并上传到指定ftp,还可以删除旧的备份文件,大家参考使用吧
    2014-01-01
  • nginx日志切割shell脚本

    nginx日志切割shell脚本

    nginx的日志文件没有rotate功能。如果你不处理,日志文件将变得越来越大,还好我们可以写一个nginx日志切割脚本来自动切割日志文件
    2014-03-03
  • linux反弹shell的原理详解

    linux反弹shell的原理详解

    这篇文章主要介绍了linux反弹shell的原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • shell脚本实现ssh自动登录功能分享

    shell脚本实现ssh自动登录功能分享

    mac下没有找到好用的类似secureCRT,就自己写了个自动登录的脚本,分享一下,如果是新浪的,就基本不用修改代码就直接能用
    2014-04-04

最新评论