Linux自动备份Mysql数据

一、自动化备份脚本

java 复制代码
#!/bin/bash
# mysql 数据库全量备份
 # 设置字符集
export LANG=en_US.UTF-8
export LC_ALL=en_US.UTF-8
# 用户名、密码、数据库名
username=""
password=""
dbName=""

backNumber=30
beginTime=`date +"%Y年%m月%d日 %H:%M:%S"`
# 备份目录
bakDir=/opt/back
# 日志文件
logFile=/opt/back/log/bak.log
# 备份文件
nowDate=`date +%Y%m%d`
dumpFile="${dbName}_${nowDate}.sql"
gzDumpFile="${dbName}_${nowDate}.tar.gz"

if [ ! -d $bakDir ];
then
	mkdir -p $bakDir;
fi
 
cd $bakDir
# 全量备份
/opt/moudel/mysql/bin/mysqldump -u${username} -p${password} \
--quick \
--databases ${dbName} \
--single-transaction \
--default-character-set=utf8 \
--set-charset=true \
--result-file=$dumpFile
# 打包
/bin/tar -zvcf $gzDumpFile $dumpFile
/bin/rm $dumpFile

endTime=`date +"%Y年%m月%d日 %H:%M:%S"`
echo "开始:$beginTime 结束:$endTime $gzDumpFile succ" >> $logFile

# 找到要删除的备份文件
delFile=`ls -l -crt $bakDir/*.tar.gz | awk '{print $9}' | head -1`
# 统计备份文件数量
count=`ls -l -crt $bakDir/*.tar.gz | awk '{print $9}' | wc -l`

if [ -n "$delFile" ] && [ "$count" -gt $backNumber ]; then
    rm $delFile
	echo "删除备份文件 $delFile" >> $logFile
fi

填写上方自动化备份代码参数,账号、密码、数据库和全量备份路径

路径查找:

复制代码
which mysqldump

查找出来后替换/opt/moudel/mysql/bin/mysqldump

创建文件夹和设置权限:

复制代码
# 创建脚本文件
sudo nano /opt/backup-mysql.sh
# 赋予执行权限
sudo chmod +x /opt/backup-mysql.sh
复制代码
# 创建备份目录和日志目录
sudo mkdir -p /opt/back/log
# 修改目录权限(根据实际情况调整)
sudo chmod 755 /opt/back
sudo chmod 755 /opt/back/log

二、运行脚本

执行:./backup-mysql.sh

发现出现报错,原因:脚本文件包含了Windows的换行符(CRLF,即\r\n),而Linux需要Unix的换行符(LF,即\n)。^M 是回车符\r的显示。

执行:sed -i 's/\r$//' backup-mysql.sh

重新执行完成后查看日志已经成功:

进入备份目录查看出现压缩包:

三、定时任务执行

每天晚上2点执行:0 2 * * * /home/backup-mysql.sh >> /opt/back/log/cron.log 2>&1

使用:crontab -l 查看是否成功添加

这里没有添加成功,手动添加

执行: crontab -e 进行手动添加

再次查看添加成功

相关推荐
十日十行13 小时前
Linux和window共享文件夹
linux
木心月转码ing20 小时前
WSL+Cpp开发环境配置
linux
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
蝎子莱莱爱打怪2 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
崔小汤呀2 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
何中应2 天前
vi编辑器使用
linux·后端·操作系统
何中应2 天前
Linux进程无法被kill
linux·后端·操作系统
何中应2 天前
rm-rf /命令操作介绍
linux·后端·操作系统
何中应2 天前
Linux常用命令
linux·操作系统
葛立国2 天前
从 / 和 /dev 说起:Linux 文件系统与挂载点一文理清
linux