自动备份MySQL数据库 [更新bug]

作者:V君 发布于:2015-6-23 22:32 Tuesday 分类:折腾手记

鉴于树莓派是用SD卡作为存储器, 然而SD卡是十分脆弱的, 

稍有不慎就会文件系统损坏,因此完善的备份措施是必不可少.

于是开始咕狗整个数据库的备份方法, 

嗯 mysqldump 这货只要指定数据库名称就能把整个数据库变成SQL输出来

接下来是遍历所有数据库, 还要排除不必要的系统数据库和架构数据库.

参考了咕狗来的一篇文章,按自己的需求改了下代码, 主要还是打日志 (=゚ω゚)=

依然是塞给crontab去执行

 

#!/bin/bash

 

# Add your backup dir location, password, mysql location and mysqldump location

DATE=$(date +%Y-%m-%d_%H-%M-%S)

BACKUP_DIR="/mnt/BackupStore/dbs"

MYSQL_HOST="192.168.***.***"

MYSQL_USER="root"

MYSQL_PASSWORD="********"

MYSQL=mysql

MYSQLDUMP=mysqldump

 

echo $DATE begin backup database

 

# To create a new directory into backup directory location

mkdir -p $BACKUP_DIR/$DATE

 

# get a list of databases

databases=`$MYSQL -h$MYSQL_HOST -u$MYSQL_USER -p$MYSQL_PASSWORD -e "SHOW DATABASES;"|grep -Ev "(information_schema|performance_schema|mysql)"|sed 1d`

# dump each database in separate name

for db in $databases; do

echo backing up $db

$MYSQLDUMP --force --opt --user=$MYSQL_USER -h$MYSQL_HOST -p$MYSQL_PASSWORD --databases $db | xz > "$BACKUP_DIR/$DATE/$db.sql.xz"

done

 

echo done.


update1:修正包含DataBase的数据库被排除


~

标签: 树莓派 数据库 linux 数据备份

引用地址:

发表评论:

Powered by emlog 去你妹的备案 sitemap