阅读背景:

定时备份mysql数据库

来源:互联网 

写一个脚本

#!/bin/bash DB_NAME=

写一个脚本

#!/bin/bash DB_NAME=$1 if [ "$DB_NAME"x == ""x ]; then echo "you need input a db name." && exit 0 fi MYSQL_HOME=/usr/local/mysql MYSQL_DUMP=$MYSQL_HOME/bin/mysqldump BACKUP_DB_DIR=/data/backup/db/$DB_NAME if [ ! -d "$BACKUP_DB_DIR" ]; then mkdir -p $BACKUP_DB_DIR fi TIME="$(date +"%Y%m%d%H%M")" $MYSQL_HOME/bin/mysqldump -uusername -ppassword db_psq |gzip > $BACKUP_DB_DIR/$DB_NAME-$TIME.sql.gz find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1

find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1

意思是在备份目录,查$DB_NAME前缀,sql.gz后缀的文件  其中-type f表示普通文件,mtime +30表示30天前的文件 ,找到文件后执行 -exec rm {} 删除, /dev/null 2>&1 就是标准错误输出到标准输出 并扔到/dev/null,也就是可以认为扔到垃圾桶啦

将shell脚本放到/usr/local/mysql/bin目录

使用方法  /usr/local/mysql/bin/mysql_backup.sh db_name

需要定时备份的话,就配一个cron定时任务

crontab -e

30 3 * * * (/usr/local/mysql/bin/mysql_backup.sh db_name) > /dev/null 2>&1

意思是每天凌晨3点30分 备份 db_name这个数据库,当然数据库里要存在这个数据库哦

if [ "$DB_NAME"x == ""x ]; then echo "you need input a db name." && exit 0 fi MYSQL_HOME=/usr/local/mysql MYSQL_DUMP=$MYSQL_HOME/bin/mysqldump BACKUP_DB_DIR=/data/backup/db/$DB_NAME if [ ! -d "$BACKUP_DB_DIR" ]; then mkdir -p $BACKUP_DB_DIR fi TIME="$(date +"%Y%m%d%H%M")" $MYSQL_HOME/bin/mysqldump -uusername -ppassword db_psq |gzip > $BACKUP_DB_DIR/$DB_NAME-$TIME.sql.gz find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1 #!/bin/bash DB_NAME=

写一个脚本

#!/bin/bash DB_NAME=$1 if [ "$DB_NAME"x == ""x ]; then echo "you need input a db name." && exit 0 fi MYSQL_HOME=/usr/local/mysql MYSQL_DUMP=$MYSQL_HOME/bin/mysqldump BACKUP_DB_DIR=/data/backup/db/$DB_NAME if [ ! -d "$BACKUP_DB_DIR" ]; then mkdir -p $BACKUP_DB_DIR fi TIME="$(date +"%Y%m%d%H%M")" $MYSQL_HOME/bin/mysqldump -uusername -ppassword db_psq |gzip > $BACKUP_DB_DIR/$DB_NAME-$TIME.sql.gz find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1

find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1

意思是在备份目录,查$DB_NAME前缀,sql.gz后缀的文件  其中-type f表示普通文件,mtime +30表示30天前的文件 ,找到文件后执行 -exec rm {} 删除, /dev/null 2>&1 就是标准错误输出到标准输出 并扔到/dev/null,也就是可以认为扔到垃圾桶啦

将shell脚本放到/usr/local/mysql/bin目录

使用方法  /usr/local/mysql/bin/mysql_backup.sh db_name

需要定时备份的话,就配一个cron定时任务

crontab -e

30 3 * * * (/usr/local/mysql/bin/mysql_backup.sh db_name) > /dev/null 2>&1

意思是每天凌晨3点30分 备份 db_name这个数据库,当然数据库里要存在这个数据库哦

if [ "$DB_NAME"x == "


你的当前访问异常,请进行认证后继续阅读剩余内容。

分享到: