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

再次查看添加成功

相关推荐
峥无几秒前
Linux 调试效率革命:CGDB
linux·运维·服务器
骥龙1 分钟前
第九篇:安全审计与运维——自动化防线建设
运维·安全·自动化
莫回首�6 小时前
ubuntu 20.04 多网卡配置,遇到问题总结
linux·网络·ubuntu
网络安全许木6 小时前
自学渗透测试第11天(Linux压缩解压与磁盘管理)
linux·网络安全·渗透测试
0xDevNull8 小时前
MySQL数据冷热分离详解
后端·mysql
航Hang*8 小时前
Windows Server 配置与管理——第3章:文件系统管理
运维·服务器·windows·vmware
一江寒逸8 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain8 小时前
linux个人心得22 (mysql)
数据库·mysql
lifewange9 小时前
Linux ps 进程查看命令详解
linux·运维·服务器