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 进行手动添加

再次查看添加成功

相关推荐
wangqiaowq21 小时前
windows下nginx的安装
linux·服务器·前端
rising start21 小时前
二、全面理解MySQL架构
mysql·架构
YYRAN_ZZU21 小时前
Petalinux新建自动脚本启动
linux
bqq198610261 天前
MySQL性能优化
mysql·mysql优化
charlie1145141911 天前
嵌入式Linux驱动开发pinctrl篇(1)——从寄存器到子系统:驱动演进之路
linux·运维·驱动开发
Agent手记1 天前
异常考勤智能预警与处理与流程优化方案 | 基于企业级Agent的超自动化实战教程
运维·人工智能·ai·自动化
于小猿Sup1 天前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
cen__y1 天前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
雨辰AI1 天前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城20241 天前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列