mysql 备份表到sql server_使用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、付费专栏及课程。

余额充值