MySQL备份脚本

MYSQL备份,每天全量备份(排除由于GTID的缘故造成恢复问题的系统库),然后通过Gzip进行压缩。

1. 准备工作

创建数据目录,修改脚本path

bash 复制代码
mkdir -p /home/dbbak/logs
mkdir -p /home/dbbak/backupdb
  1. 查看mysql路径 修改脚本mysql路径
bash 复制代码
 ps -ef |grep mysql
mysql      91770       1 19 Mar23 ?        3-12:33:51 /usr/sbin/mysqld
root      941954  941037  0 11:04 pts/0    00:00:00 grep --color=auto mysql
which mysql
/usr/bin/mysql

2. 脚本修改并执行

bash 复制代码
#!/bin/bash

#DEFINE VARIABLES
BACKUPUSER=root
BACKUPPASS="root密码"
BACKUPPORT=mysql端口
#BACKUPSOCKET=/home/data/$BACKUPPORT/logs/mysql.sock
BACKUPIP=localhost
MYSQL=/usr/local/mysql/bin/mysql
MYSQLDUMP=/usr/local/mysql/bin/mysqldump
#CONFIG_FILE=/home/data/$BACKUPPORT/conf/my.cnf
BINLOGPATH=/home/dbbak/logs
BACKUPPATH=/home/dbbak/backupdb
DEL_DIRECTORY=`date +%Y%m%d -d "-14 day"`
BACKUPDATE=`date +%Y%m%d`

mkdir $BACKUPPATH/$BACKUPDATE

#connection  to mysql db
mycmd="$MYSQL -u$BACKUPUSER -p$BACKUPPASS -h$BACKUPIP -P$BACKUPPORT"

#backup metadata
DUMP_Table="$MYSQLDUMP -u$BACKUPUSER -p$BACKUPPASS -h$BACKUPIP  -P$BACKUPPORT  -R --events -d"

# backup database for InnoDB
DUMP_InnoDB="$MYSQLDUMP -u$BACKUPUSER -p$BACKUPPASS -h$BACKUPIP -P$BACKUPPORT   --flush-privileges --single-transaction --master-data=2 --set-gtid-purged=OFF --triggers -f -R -E --hex-blob
 "

# backup database for MyISAM
DUMP_MYISAM="$MYSQLDUMP -u$BACKUPUSER -p$BACKUPPASS -h$BACKUPIP -P$BACKUPPORT   --flush-privileges --lock-all-tables --master-data=2 --triggers -f -F -R -E --hex-blob "

echo  `date +%F" "%r` "Start backup  Mysql  databases" >> $BINLOGPATH/$BACKUPDATE.log


#flush logs
$mycmd -e 'flush logs'

#backup config file
#/bin/cp  $CONFIG_FILE  $BACKUPPATH/$BACKUPDATE


#backup binary log file
BINLOG=`find  $BINLOGPATH  -type  f  -name "mysql_bin*" -mtime -2 |grep -v index `
for  i in  $BINLOG  
do
 /bin/cp $i  $BACKUPPATH/$BACKUPDATE/$BACKUPPORT
done


# backup  and compress 
#有些时候,我们要对数据库进行备份的时候,由于GTID的缘故,导出系统库后,再次导入其他环境的数据库时,就会出问题。所以,我们需要排掉一些系统库,排除GTID对于数据库迁移的影响。

db=`$mycmd  -e "show databases;"|grep -Evw "Database|information_schema|performance_schema|test|mysql|sys"`
${DUMP_InnoDB} --databases $db --ignore-table=要忽略的表 |gzip > $BACKUPPATH/$BACKUPDATE/full_$(date +%w).sql.gz

#flush logs
$mycmd -e 'flush logs'

解压缩方法:使用gunzip gunzip full_2.sql.gz

相关推荐
数据库知识分享者小北7 小时前
告别后端上下文断层!体验用 PolarDB Supabase 助力 AI 原生 IDE 完成 VibeCoding领取试用及多重好礼
数据库·人工智能·阿里云·关系型数据库·polardb·vibecoding
ea4on7 小时前
看完这篇,我才MySQL索引是这样理解的
数据库
鬼先生_sir8 小时前
MySQL进阶基础:索引、视图、存储过程与常用函数
数据库·mysql
Nturmoils8 小时前
实时决策时代,工业物联网需要什么样的数据库?
数据库·后端
Flying pigs~~8 小时前
RAG前身:基于mysql➕redis➕bm25的传统QA问答系统
数据库·redis·缓存·大模型·qa·rag·prompt提示词
fly spider8 小时前
MySQL数据存储详解
数据库·mysql
D4c-lovetrain8 小时前
Linux个人心得25 (mysql⑤)
linux·运维·mysql
档案宝档案管理8 小时前
2026档案管理系统排名解析,易用性+安全性双维度对比
大数据·数据库·人工智能·档案管理
AllData公司负责人8 小时前
AllData数据中台集成开源项目Apache Doris建设实时数仓平台
java·大数据·数据库·数据仓库·apache doris·实时数仓平台·doris集群