一个简单的mysql备份脚本用于线上备份

本文分享了一个简单的MySQL在线备份Shell脚本,该脚本利用Shell数组进行数据库列表的管理,并通过mysqldump工具实现数据库的增量备份。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

其实这个脚本是在网上看到的,它是一个简单的mysql备份脚本用于线上备份,正好在这里引用到了shell数组。
只是在这里提醒一下shell中的数组使用技巧,现在拿来和大家分享:

#!/bin/bash
suffix=$(date +%m-%d-%Y)
cpath=/data/mysql/backup
dblist=(netseek mysql test)
sockpath="/data/mysql/3306/mysql.sock"

for ((i=0; i<${#dblist[@]};i++))
do
if [ -d $cpath ]
then
# direcotry exists, we're good to continue
filler="just some action to prevent syntax error"
else
#we need to make the directory
echo Creating $cpath
mkdir -p $cpath
fi

#now backup db
sqlfile=${cpath}/${dblist[$i]}_$suffix.sql.gz
mysqldump -S ${sockpath} --single-transaction --flush-logs --master-data=2 ${dblist[$i]}|gzip -c > $sqlfile

if [ $? -eq 0 ]
then
printf "%s was backed up successfully to %s\n\n" ${dblist[$i]} $sqlfile
else
printf "WARNING: An error occured while attempting to backup %s to %s\n\n" ${dblist[$i]} $sqlfile
fi
done

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值