Linux 网站文件+数据库 定时备份到七牛云储存 脚本
没有面板和插件的话,还是需要备份网站脚本的,所以我还是保存一份七牛备份脚本,直接vps自动任务备份,以防不测。
本脚本Github项目地址:https://github.com/ccbikai/backuptoqiniu
七牛新建储存空间+获取七牛密匙
要看这个教程,首先你要有一个 七牛云的账号,没有就注册一个。
注意:七牛注册后会送1G流量和空间,还需要实名认证后,才会送10G流量和空间,有实名认证洁癖的不需要往下面看了。
注册并实名认证后,打开 七牛云控制面板页面。
然后点击控制台左边侧栏的 对象储存,然后点击 新建储存空间。
然后输入 储存空间名称(后面需要使用)、选择 储存区域(随便哪个都行)、访问控制选择 私有空间 ,确定无误后点击 确定创建 按钮。
然后我们还需要七牛密匙,点击七牛控制面板右上角 个人面板 – 密匙管理。
然后会看到你的密匙,如果没有请创建,我是以前创建了两个,随便选一个就行了。
复制 AK和SK两行文本 ,随后脚本有用。
安装环境
首先这个脚本需要用到 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://softs.fun/Website/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
正常情况下,应该提示是这样的:
root@doubi:~# 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 * * 指的是,每天凌晨 2 点 0 分执行一次备份脚本。
* * * * * 分别对应的是 分钟 小时 日 月 星期 。
如果你要每隔 3天备份一次,那么改成 0 2 */3 * * ,这样就是每隔 3 天凌晨 2 点 0 分执行一次。
更多的使用方法请百度谷歌 crontab 定时用法。
当你添加完 定时任务代码后,
如果你的 crontab 是 vim 编辑器,那么按 ESC 键 退出编辑模式,然后输入 *:wq 保存并退出。
如果你的 crontab 是 nano 编辑器,那么按 Ctrl+X 退出,然后提示你内容已更改 是否保存,按 y 键 ,然后再按 回车键 就好了。
来源:逗比根据地