mysql逻辑备份与还原,备份shell脚本

本文介绍了如何使用mysqldump进行MySQL数据库的逻辑备份,包括备份所有数据库、单个数据库、多个数据库以及特定表的方法,并详细阐述了数据的还原过程,包括全量还原和单个库的还原操作。此外,还提到了实现备份的shell脚本实践。
摘要由CSDN通过智能技术生成

mysqldump说明:

   Usage: mysqldump [OPTIONS] database [tables]
   OR     mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]
   OR     mysqldump [OPTIONS] --all-databases [OPTIONS]

示例:

mkdir -p /data/backup/mysql

数据备份:mysqldump -uroot -p密码 备份库>/data/backup/mysql/xx.sql

备份库说明:

备份所有库:  --all-databases

备份单个库: 库名

备份多个库:---databases 库1 库2

备份指定表:库名1 表1 表2

 

还原:

全部还原:mysql -uroot -p密码 -e "\. 备份文件" 或mysql -uroot -p密码 </data/backup/mysql/xx.sql

从备份中还原单个库:mysql -uroot -p密码 --one-database 还原库</data/backup/mysql/xx.sql

备份shell脚本:

#!/bin/bash
#auto backup mysql
#by author yu 2020/2/2


green(){
  echo -e "\033[32m$*\033[0m"
}

red(){
    echo -e "\033[31m$*\033[0m"
}

BACKUP_DIR=/data/backup/mysql/`date +%Y-%m-%d`
BACKUP_DB=--all-databases
MYSQL_USER=root
MYSQL_PWD=123456
MYSQL_PORT=3306
#必须使用root用户执行该脚本,root用户的UID为0
if [ ! $UID -eq 0 ];then
  red "Backup failure"
  echo "Execute the script using root!!"
  sleep 2
  exit 1
fi
#创建备份目录
if [ ! -d $BACKUP_DIR ];then
  mkdir -p $BACKUP_DIR
fi
#使用mysqldump命令进行逻辑备份
mysqldump -u"$MYSQL_USER" -p"$BACKUP_PWD" -P"MYSQL_PORT" "BACKUP_DB" > "$BACKUP_DIR"/mysqlbk.sql

[ $? -eq 0 ]&& green "backup successful"||red "Backup failure"

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值