使用mysqldump备份数据库

MySQL单个数据库备份:

mysqldump --force --opt --single-transaction --lock-tables=false --skip-events --user=root --password=xxxx --routines --databases testdb > singledb.sql

 

MySQL所有数据库备份:

mysqldump --force --opt --single-transaction --lock-tables=false --skip-events --user=root --password=xxxx --routines --all-databases > all_databases.sql

 

MySQL数据库还原:

mysql -u root -predhat dbname < /mnt/dbname.sql


MySQL数据库备份的Shell脚本:    
#  mkdir /backups/db_backup/

# vi /backups/mysqlbackup.sh

#!/bin/bash  
export path1=/backups/db_backup    
date1=`date +%y%m%d_%H%M%S`    
/usr/bin/find /backups/db_backup/* -type d -mtime +30 -exec rm -r {} \; 2> /dev/null    
cd $path1/    
mkdir $date1    
USER="root"    
PASSWORD="redhat123"    
OUTPUTDIR="$path1/$date1"    
MYSQLDUMP="/usr/bin/mysqldump"    
MYSQL="/usr/bin/mysql"    
HOST="localhost"    
databases=`$MYSQL --user=$USER --password=$PASSWORD --host=$HOST \    
-e "SHOW DATABASES;" | tr -d "| " | grep -v Database`    
echo "` for db in $databases; do    
   echo $db

       if [ "$db" = "performance_schema" ] ; then  
       $MYSQLDUMP --force --opt --single-transaction --lock-tables=false --skip-events --user=$USER --password=$PASSWORD --host=$HOST --routines \    
        --databases $db | gzip > "$OUTPUTDIR/$db.gz"    
        else

$MYSQLDUMP --force --opt --single-transaction --lock-tables=false --events --user=$USER --password=$PASSWORD --host=$HOST --routines \  
   --databases $db | gzip > "$OUTPUTDIR/$db.gz"    
fi    
done `"

:wq

 

在crontab里配置调度:  
#The  script will run every night at 12 A.M    
#crontab -e    
0 0 * * * /backups/mysqlbackup.sh > /dev/null


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值