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

相关推荐
科技小花1 天前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56611 天前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全1 天前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717211 天前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
绘梨衣5471 天前
Docker+FastAPI+MySQL 项目部署报错汇总
mysql·docker·fastapi
小江的记录本1 天前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi1 天前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai1 天前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw01 天前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209251 天前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql