[debian 9]debian vps网站自动备份脚本分享

更新时间:2019-10-11    来源:linux    手机版     字体:

【www.bbyears.com--linux】

debian系统占用内存少,负载均衡,但是如果没有控制面板的话,管理起来就只能通过ssh中使用linux命令来管理。对于不熟悉linux命令的人来说确实比较麻烦。本篇将详细地分步骤介绍如何在debian系统下,使用linux命令实现定时自动备份网站数据。(本文备份方法适用于所有linux系统非必须debian)
vps系统环境

系统说明


vps主机内存256MB,硬盘空间 20GB;系统为debian 6 32位;安装的是lnmp。

先给一份手动备份网站的列子:


cd /home/
mkdir backup

cd backup
mkdir www
mkdir mysql

cd /root/
touch backup.sh
chmod +x backup.sh

vim backup.sh 添加如下内容:
cd /home/backup/mysql/
mysqldump -h localhost -u数据库用户名 -p数据库密码  数据库名称| gzip >数据库名称-$(date +%Y%m%d).sql.gz
tar zcvf /home/backup/www/111cn.net_$(date +%Y%m%d).tar.gz -C /home/wwwroot zxsdw
如上操作后,要手动备份数据只需运行 sh /root/backup.sh 即可
要自动备份可运行:crontab -e 命令添加如下内容:0 2 * * * sh /root/backup.sh

linux备份各步骤详细解说:
以111cn.net为例:网站安装在/home/wwwroot/111cn.net/目录下;备份文件打算放在/home/backup/下,为了使备份信息更清晰,将网站文件备份在在/home/backup/www/下,将mysql数据库备份放在/home/backup/mysql/下。
需要提前做
在/home/下创建backup文件夹,然后在/home/backup/下再创建www和mysql文件夹。使用root登录后,如下操作
cd /home/

mkdir backup

cd backup

mkdir www

mkdir mysql
创建备份脚本
使用root登录vps后,默认目录就是/root/(如果不是,可以用cd /root/切换到root目录下),首先可以在/root/文件下运行如下:
touch backup.sh

chmod +x backup.sh

vim backup.sh
创建一个backup.sh的执行文件,通过chmod设置其可读写,并用vim编辑这个文件。
下面就是通过vim编辑backup.sh中要添加的内容,如下:
1.创建数据库备份脚本

cd /home/backup/mysql/

#将mysql的备份放到/home/backup/mysql/下,所以首先cd到这个目录。
mysqldump -h localhost -u数据库用户名 -p数据库密码  数据库名称| gzip >数据库名称-$(date +%Y%m%d).sql.gz


#这段就是数据库中的各个数据库分开备份并且采用gzip压缩,导出为“数据库名称-年月日.sql.gz”这样的格式。gzip压缩后的sql数据库备份文件更小,恢复数据的时候可以直接导入sql.gz的备份文件来恢复。
2.创建网站文件备份脚本

#绝对路径备份(通俗点说就是点开压缩包先进入home,下面还有wwwroot,就是一级一级打开,最后才是网站的文件夹)
tar zPcf /home/backup/www/111cn.net_$(date +%Y%m%d).tar.gz /home/wwwroot/111cn.net/

#相对路径备份 (压缩包只有111cn.net这个文件夹及文件夹下面的网站数据)
tar zPcf /home/backup/www/111cn.net_$(date +%Y%m%d).tar.gz -C /home/wwwroot 111cn.net


#以上为实例,根据你的实际情况修改。此段111cn.net的网站文件放在vps的/home/wwwroot/111cn.net/下,然后使用tar压缩命令将此文件下的所有文件备份保存到/home/backup/www/文件下,然后保存为“111cn.net_年月日.tar.gz”的压缩文件。
3.创建网站日志备份脚本(可选)

网站访问日志一般放在wwwlogs下,个人比较喜欢通过分析网站日志来了解搜索引擎的抓取和搜索情况,所以我想分开备份每天的log网站日志。创建如下脚本:
tar zPcf /home/backup/log_$(date +%Y%m%d).tar.gz /home/wwwlogs/


为了实现将网站日志按日每天分开备份,以便了解每天的网站抓取和收录情况,在备份日志后将原来的日志删除,重新创建一个新的空白日志文件,再添加如下(以www.111cn.net为例):

rm -rf /home/wwwlogs/*.*

cd /home/wwwlogs/

touch www.111cn.net.log
添加删除旧的备份脚本
使用vim backup.sh命令然后添加如下:

find /home/backup/ -type f -mtime +2 -exec rm -f {} \;

find /home/backup/www/ -type f -mtime +2 -exec rm -f {} \;

find /home/backup/mysql/ -type f -mtime +2 -exec rm -f {} \;

#这段为,分别删除/home/backup/及其下面的子目录www和mysql下的2天前生成的旧的备份文件。
将这些内容使用vim编辑添加到backup.sh中后,保存退出。因为backup.sh放置在/root/目录下,所以接下来测试运行:
sh /root/backup.sh

运行该命令后,如果没有出现错误提示一般就说明这个备份脚本创建成功了,然后你通过查看/home/backup/及其子目录下是否生成了备份文件可以确定是否备份成功。
设置vps自动定时备份
要实现自动备份必须使用linux下的cron定时任务工具。以我的vps系统debian6 32系统为例说明。
通过命令crontab -e添加如下内容:

0 12 * * * sh /root/backup.sh

说明:我设置每天凌晨3点运行备份脚本。但是通过测试发现,我的香港vps的时间貌似和北京时间有时差。如上,我设置12点对应运行的应该是北京时间凌晨3点。
至此,我的debian vps在lnmp下定时自动备份网站设置成功。实现了每天凌晨3点备份网站文件、数据库数据和网站访问日志,我就可以同过sftp从/home/backup/中下载备份文件了

好了如果各位还有另一台服务器我们可以使用scp命令来远程备份 或使用rsycn同步工具来同步了,下面我们看个scp备份 文件例子

将本地文件上传到服务器上

scp -P 2222 /home/lnmp0.4.tar.gz root@www.111cn.net:/root/lnmp0.4.tar.gz

上端口大写P 为参数,2222 表示更改SSH端口后的端口,如果没有更改SSH端口可以不用添加该参数。 /home/lnmp0.4.tar.gz表示本地上准备上传文件的路径和文件名。root@www.111cn.net 表示使用root用户登录远程服务器www.111cn.net,:/root/lnmp0.4.tar.gz 表示保存在远程服务器上目录和文件名。

4、将本地目录上传到服务器上

scp -P 2222 -r /home/lnmp0.4/ root@www.111cn.net:/root/lnmp0.4/

上 端口大写P 为参数,2222 表示更改SSH端口后的端口,如果没有更改SSH端口可以不用添加该参数。-r 参数表示递归复制(即复制该目录下面的文件和目录);/home/lnmp0.4/表示准备要上传的目录,root@www.111cn.net 表示使用root用户登录远程服务器www.111cn.net,:/root/lnmp0.4/ 表示保存在远程服务器上的目录位置。

5、可能有用的几个参数 :

-v 和大多数 linux 命令中的 -v 意思一样 , 用来显示进度 . 可以用来查看连接 , 认证 , 或是配置错误 .

-C 使能压缩选项 .

-4 强行使用 IPV4 地址 .

-6 强行使用 IPV6 地址 .

本文来源:http://www.bbyears.com/caozuoxitong/72592.html