一个备份mysql 数据库的脚本

# 获取当前系统日期,格式为: 2009-2-21
DATE=`date "+%F"`

# 定义mysql 服务的主目录
DB_DIR=/usr

# 定义备份后的路径
BAK_DIR=/usr/local/backup
BAK_PATH=$BAK_DIR/$DATE

# 判断备份文件存放的路径是否存在
if [ ! -d $BAK_PATH ];then
mkdir -p $BAK_PATH
fi

#目录查看有哪些数据库
cd /var/lib/mysql
DB_NAME=`ls -dF -1 * | grep "/$" | cut -d/ -f1`

# 利用mysqldump 对所有数据库进行SQL语句备份
for db_name in $DB_NAME;
do
$DB_DIR/bin/mysqldump -u root -p"*****" $db_name > $BAK_PATH/$db_name-$DATE.sql;
done

# 删除15天以前备份的文件
find $BAK_DIR -name "*" -mtime +15 |xargs rm -rf
exit 0

代码执行结果:

[root@weifeng01 ~]# ./mysqlbackup.sh
/usr/local/backup/2017-10-10
Enter password:
[root@weifeng01 ~]# cd /usr/local/backup/
[root@weifeng01 backup]# ls
2017-10-10
[root@weifeng01 backup]# cd 2017-10-10/
[root@weifeng01 2017-10-10]# ls
apim-2017-10-10.sql

posted @ 2017-10-11 10:53  Oops!#  阅读(287)  评论(0编辑  收藏  举报