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"