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

再次查看添加成功

相关推荐
m0_683124794 分钟前
Ubuntu服务设置开机自启
linux·运维·ubuntu
BestOrNothing_20158 分钟前
(1)双系统中Ubuntu22.04启动盘制作与启动盘恢复全过程
linux·ubuntu·双系统·启动盘制作·启动盘恢复
AI成长日志12 分钟前
【实用工具教程】Linux常用命令速查与实战场景:文件操作、进程管理与网络调试高频命令解析
linux·php
落叶花开又一年17 分钟前
检验检测机构资质认定远程评审工作程序
linux·运维·服务器
wanhengidc17 分钟前
《三国志异闻录》搬砖新游戏 云手机
运维·服务器·数据库·游戏·智能手机
idolao24 分钟前
CentOS 7 安装 jdk-7u25-linux-x64.tar.gz 详细步骤(解压配置环境变量)
linux
i建模38 分钟前
通过命令行使用密钥登录远程SSH主机
运维·ssh
旺仔.2911 小时前
僵死进程及Linux文件操作 详解
linux·运维·服务器
ShiJiuD6668889991 小时前
mysql 基础笔记一
数据库·笔记·mysql
IMPYLH1 小时前
Linux 的 comm 命令
linux·运维·算法