Linux 网站文件+数据库 定时备份到七牛云储存 脚本

认真的做网站,不仅需要一个稳定的主机(VPS),还需要定时备份自己的网站数据和数据库,毕竟再稳定的主机(VPS)也有可能出问题,不过大部分情况下都是自己折腾导致的问题,所以定时备份是必不可少的。


backup
本脚本Github项目地址:https://github.com/ccbikai/backuptoqiniu


  • 七牛新建储存空间+获取七牛密匙

要看这个教程,首先你要有一个 七牛云的账号,没有就注册一个

注意:七牛注册后会送1G流量和空间,还需要实名认证后,才会送10G流量和空间,有实名认证洁癖的不需要往下面看了。

注册并实名认证后,打开 七牛云控制面板页面。

然后点击控制台左边侧栏对象储存,然后点击 新建储存空间

然后输入 储存空间名称(后面需要使用)、选择 储存区域(随便哪个都行)、访问控制选择 私有空间 ,确定无误后点击 确定创建 按钮。

然后我们还需要七牛密匙,点击七牛控制面板右上角 个人面板密匙管理

然后会看到你的密匙,如果没有请创建,我是以前创建了两个,随便选一个就行了。

复制 AKSK 两行文本 ,随后脚本有用。

  • 安装环境

首先这个脚本需要用到 python,所以先确定你VPS的 python 版本是否是2.7以上。

python -V

如果低于 2.7 版本,那你就需要升级python版本,才能继续看教程了。

脚本需要用到 zip 解压缩,所以需要安装 zip和unzip 。

CentOS系统:
yum update && yum install -y zip unzip
Debian/Ubuntu系统:
apt-get update && apt-get install -y zip unzip

下面开始安装脚本

  • 安装脚本

接下来就是安装和设置脚本了。

wget --no-check-certificate -O backuptoqiniu.zip https://share.imwnk.cn/%E5%85%B6%E5%AE%83/backuptoqiniu.zip
unzip backuptoqiniu.zip && cd backuptoqiniu
python setup.py install

安装很快,如果没有报错,那么就继续下一步。

  • 设置脚本

backuptoqiniu 文件夹中有一个 backuptoqiniu.sh 脚本文件,里面设置的是配置信息。

我们可以把这个文件通过SFTP下载到本地修改,也可以在SSH用 VI 中修改。

vi backuptoqiniu.sh

打开文件后,我们只要看前半部分就行了。

## 备份配置信息 ##
# 备份名称,用于标记
BACKUP_NAME="qiniu"
# 备份目录,多个请空格分隔
BACKUP_SRC="/home/wwwroot/xxx.xxx"
# Mysql主机地址
MYSQL_SERVER="localhost"
# Mysql用户名
MYSQL_USER="root"
# Mysql密码
MYSQL_PASS="mysqlpassword"
# Mysql备份数据库,多个请空格分隔
MYSQL_DBS="dbname"
# 备份文件临时存放目录,一般不需要更改
BACKUP_DIR="/tmp/backuptoqiniu"
# 备份文件压缩密码确保压缩包的安全
BACKUP_FILE_PASSWD="doub.io"
## 备份配置信息 End ##
## 七牛配置信息 ##
#存放空间对应我们在七牛上创建的文件夹
QINIU_BUCKET="doubi"
QINIU_ACCESS_KEY="ACCESS_KEY"
QINIU_SECRET_KEY="SECRET_KEY"
## 七牛配置信息 End ## 

根据中文注释提示来修改各参数设置。

需要注意的是如果你要备份多个目录,那 BACKUP_SRC 参数要用空格隔开多个目录,这样写:

BACKUP_SRC="/home/wwwroot/xxx.xxx /home/wwwroot/yyy.yyy /home/wwwroot/zzz.zzz"

数据库也一样,假如你有三个数据库,名称分别为 xxx yyy zzz ,那么就这样写:

MYSQL_DBS="xxx yyy zzz"

重点说的是 七牛配置信息。

在上面我们已经 新建储存空间 了,而当时填写的 储存空间名称 就是这里的 QINIU_BUCKET 参数。

QINIU_ACCESS_KEY 对应的是 上面获取七牛密匙的 AK 代码。

QINIU_SECRET_KEY 对应的是 上面获取七牛密匙的 SK 代码。

这三个一定不能填写错误,否则会无法链接到七牛云储存空间来上传备份文件。

设置完毕后,我们可以尝试运行脚本测试一下。

chmod +x backuptoqiniu.sh
#赋予脚本执行权限
bash backuptoqiniu.sh

正常情况下,应该提示是这样的:

#bash backuptoqiniu.sh
start dump mysql
dump ok
start tar
tar ok
start upload
upload ok
backup clean done

如果提示正常,可以去 七牛控制面板 查看是否上传成功。

  • 设置定时任务

既然是备份,那就要设置定时任务,定时备份,我用的是 crontab ,如果你没有安装请安装:

CentOS系统:
yum install -y crond
 
Debian/Ubuntu系统:
apt-get install -y cron

然后因为各VPS的时区和VPS本地有关,所以你需要把VPS的时区改为北京时区。

cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

可能会提示是否覆盖,根据提示输入 y 或者 yes
设置完VPS的时区还不行,还需要重启一下 crontab ,这样 crontab 才会使用VPS的时区。

CentOS系统:
service crond restart
 
Debian/Ubuntu系统:
service cron restart

以上都设置完了,就可以开始设置 定时任务了。

假设你上面的安装脚本步骤都是在 root 目录下执行的,那么你的 七牛脚本位置就是 /root/backuptoqiniu/backuptoqiniu.sh ,如果不是,那么请自行修改目录。

打开 crontab 编辑模式(如果crontab是vim编辑器,那么需要按 I键 进入编辑模式,如果是nano编辑器那么可以直接输入),在最后加入下面的定时任务代码:

crontab -e
# 下面是定时任务代码
0 2 * * * /bin/bash /root/backuptoqiniu/backuptoqiniu.sh
#也可以设置为每周备份
0 2 * * 0 /bin/bash /root/backuptoqiniu/backuptoqiniu.sh

0 2 * * * 指的是,每天凌晨2点0分执行一次备份脚本。

0 2 * * 0 指的是,每周日凌晨2点0分执行一次备份脚本。

* * * * * 分别对应的是 分钟 小时 日 月 星期 。

如果你要每隔 3天备份一次,那么改成 0 2 */3 * * ,这样就是每隔 3天凌晨2点0分执行一次。

更多的使用方法请百度谷歌 crontab定时用法

当你添加完 定时任务代码后,

如果你的 crontab 是 vim编辑器,那么按 ESC键 退出编辑模式,然后输入 :wq 保存并退出。

如果你的 crontab 是 nano编辑器,那么按 Ctrl+X 退出,然后提示你内容已更改 是否保存,按 y键 ,然后再按 回车键 就好了。


本文章转载自:https://doub.io/wlzy-29/

微信打赏微信打赏
支付宝打赏支付宝打赏

评论: