mirror of https://github.com/einverne/dotfiles.git
Ein Verne
7 years ago
2 changed files with 146 additions and 0 deletions
@ -0,0 +1,98 @@ |
|||||||
|
#!/bin/bash |
||||||
|
|
||||||
|
# https://github.com/Ecareyu/backup2qiniu |
||||||
|
# 在官网找最新版 https://developer.qiniu.com/kodo/tools/1302/qshell |
||||||
|
QSHELL_URL="https://dn-devtools.qbox.me/2.1.5/qshell-linux-x64" |
||||||
|
|
||||||
|
## 备份配置信息 ## |
||||||
|
|
||||||
|
# qshell路径 |
||||||
|
QSHELL="/usr/local/bin/qshell" |
||||||
|
# 备份名称,用于文件名标记 |
||||||
|
BACKUP_NAME="" |
||||||
|
# 需要备份的目录,多个请空格分隔 |
||||||
|
BACKUP_SRC="" |
||||||
|
# Mysql主机地址 |
||||||
|
MYSQL_SERVER="localhost" |
||||||
|
# Mysql用户名 |
||||||
|
MYSQL_USER="" |
||||||
|
# Mysql密码 |
||||||
|
MYSQL_PASS="" |
||||||
|
# Mysql备份数据库,多个请空格分隔 |
||||||
|
MYSQL_DBS="" |
||||||
|
# 备份文件临时存放目录,一般不需要更改 |
||||||
|
BACKUP_DIR="/tmp/backuptoqiniu" |
||||||
|
# 备份文件压缩密码确保压缩包的安全 |
||||||
|
BACKUP_FILE_PASSWD="" |
||||||
|
# 子目录名,为空时获取服务器hostname作为子目录名 |
||||||
|
SUB_DIR_NAME="" |
||||||
|
|
||||||
|
## 备份配置信息 End ## |
||||||
|
|
||||||
|
## 七牛配置信息 ## |
||||||
|
|
||||||
|
# 存放空间对应我们在七牛上创建的容器 |
||||||
|
QINIU_BUCKET="" |
||||||
|
QINIU_ACCESS_KEY="" |
||||||
|
QINIU_SECRET_KEY="" |
||||||
|
|
||||||
|
## 七牛配置信息 End ## |
||||||
|
|
||||||
|
# 修复crontab执行时的报错 |
||||||
|
cd `dirname $0` |
||||||
|
|
||||||
|
# 设置子目录名 |
||||||
|
if [ ! -n "$SUB_DIR_NAME" ]; then |
||||||
|
SUB_DIR_NAME=`hostname` |
||||||
|
fi |
||||||
|
|
||||||
|
if [ ! -f "$QSHELL" ]; then |
||||||
|
echo "qshell not found, install from this link https://github.com/qiniu/qshell" |
||||||
|
wget -O qshell $QSHELL_URL |
||||||
|
mv qshell /usr/local/bin/ |
||||||
|
chmod +x /usr/local/bin/qshell |
||||||
|
fi |
||||||
|
|
||||||
|
# qshell设置用户 |
||||||
|
$QSHELL account $QINIU_ACCESS_KEY $QINIU_SECRET_KEY |
||||||
|
|
||||||
|
if [ 0 != $? ]; then |
||||||
|
echo "Authorization error" |
||||||
|
exit; |
||||||
|
fi |
||||||
|
|
||||||
|
#精确到秒,同一秒内上传的文件会被覆盖 |
||||||
|
NOW=$(date +"%Y-%m-%d-%H-%M-%S") |
||||||
|
|
||||||
|
mkdir -p $BACKUP_DIR |
||||||
|
|
||||||
|
# 备份Mysql |
||||||
|
echo "start dump mysql" |
||||||
|
for db_name in $MYSQL_DBS |
||||||
|
do |
||||||
|
mysqldump -u $MYSQL_USER -h $MYSQL_SERVER -p$MYSQL_PASS $db_name > "$BACKUP_DIR/$BACKUP_NAME-$db_name.sql" |
||||||
|
done |
||||||
|
echo "dump ok" |
||||||
|
|
||||||
|
# 打包 |
||||||
|
echo "start tar" |
||||||
|
BACKUP_FILENAME="$BACKUP_NAME-backup-$NOW.zip" |
||||||
|
tarCommand="zip -q -r" |
||||||
|
|
||||||
|
# 判定是否需要密码参数 |
||||||
|
if [ -n "$BACKUP_FILE_PASSWD" ]; then |
||||||
|
tarCommand="$tarCommand -P $BACKUP_FILE_PASSWD" |
||||||
|
fi |
||||||
|
|
||||||
|
# 到目录中压缩,防止压缩包出现过多目录结构 |
||||||
|
pushd $BACKUP_DIR && $tarCommand $BACKUP_FILENAME *.sql $BACKUP_SRC && popd |
||||||
|
echo "tar ok" |
||||||
|
|
||||||
|
# 上传,默认100条线程,管它呢 |
||||||
|
echo "start upload" |
||||||
|
$QSHELL rput $QINIU_BUCKET $SUB_DIR_NAME/$BACKUP_FILENAME $BACKUP_DIR/$BACKUP_FILENAME |
||||||
|
echo "upload ok" |
||||||
|
|
||||||
|
# 清理备份文件 |
||||||
|
rm -rf $BACKUP_DIR |
||||||
|
echo "backup clean done" |
@ -0,0 +1,48 @@ |
|||||||
|
#!/bin/bash |
||||||
|
|
||||||
|
# This script creates a compressed backup archive of the given directory and the given MySQL table. More details on implementation here: http://theme.fm |
||||||
|
# Feel free to use this script wherever you want, however you want. We produce open source, GPLv2 licensed stuff. |
||||||
|
# Author: Konstantin Kovshenin exclusively for Theme.fm in June, 2011 |
||||||
|
# https://theme.fm/a-shell-script-for-a-complete-wordpress-backup/ |
||||||
|
|
||||||
|
# Set the date format, filename and the directories where your backup files will be placed and which directory will be archived. |
||||||
|
NOW=$(date +"%Y-%m-%d-%H-%M") |
||||||
|
FILE="www.einverne.info.$NOW.tar" |
||||||
|
GZ_FILE=$FILE.gz |
||||||
|
BACKUP_DIR="/root/backups" |
||||||
|
WWW_DIR="/var/www/www.einverne.info/html" |
||||||
|
EMAIL_ADDR="[email protected]" |
||||||
|
|
||||||
|
mkdir -p $BACKUP_DIR |
||||||
|
|
||||||
|
# MySQL database credentials |
||||||
|
DB_USER="" |
||||||
|
DB_PASS="" |
||||||
|
DB_NAME="" |
||||||
|
DB_FILE="www.einverne.info.$NOW.sql" |
||||||
|
|
||||||
|
# Tar transforms for better archive structure. |
||||||
|
WWW_TRANSFORM='s,^var/www/www.einverne.info/html,html,' |
||||||
|
DB_TRANSFORM='s,^root/backups,database,' |
||||||
|
|
||||||
|
# 以上内容需要自定义 |
||||||
|
|
||||||
|
# Create the archive and the MySQL dump |
||||||
|
tar -cvf $BACKUP_DIR/$FILE --transform $WWW_TRANSFORM $WWW_DIR |
||||||
|
mysqldump -u$DB_USER -p$DB_PASS $DB_NAME > $BACKUP_DIR/$DB_FILE |
||||||
|
|
||||||
|
# Append the dump to the archive, remove the dump and compress the whole archive. |
||||||
|
tar --append --file=$BACKUP_DIR/$FILE --transform $DB_TRANSFORM $BACKUP_DIR/$DB_FILE |
||||||
|
rm $BACKUP_DIR/$DB_FILE |
||||||
|
gzip -9 $BACKUP_DIR/$FILE |
||||||
|
|
||||||
|
# Split file and send by email |
||||||
|
split -b 5M $BACKUP_DIR/$GZ_FILE $BACKUP_DIR/$GZ_FILE. |
||||||
|
rm $BACKUP_DIR/$GZ_FILE |
||||||
|
|
||||||
|
for filename in $BACKUP_DIR/*; do |
||||||
|
echo $filename |
||||||
|
echo "backup" | mutt -s "$GZ_FILE" $EMAIL_ADDR -a $filename |
||||||
|
done |
||||||
|
|
||||||
|
rm -rf $BACKUP_DIR |
Loading…
Reference in new issue