MySQL数据库全库备份及增量备份脚本
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,脚本网盘链接下载。1、全库备份脚本如下:#!/bin/bash############### 定义默认值 #################user='root'passwd='123.com'h
千家信息网最后更新 2025年11月09日MySQL数据库全库备份及增量备份脚本
脚本网盘链接下载。
1、全库备份脚本如下:
#!/bin/bash############### 定义默认值 #################user='root'passwd='123.com'host='localhost'today=`date '+%F'`dump_cmd='/usr/local/mysql/bin/mysqldump'full_backupdir="/opt/database/full_backup/"email='916551516@qq.com'################### 加载变量并定义脚本用法 ###################USAGE(){echo -e "\033[33m $0 脚本用法: -u: 指定备份用户(默认是root) -p: 指定用户密码(默认密码为"123.com") -h: 指定备份主机(默认是本机) -d: 指定要备份的数据库(默认备份所有库) \033[0m"}if [[ $1 == '--help' || $1 == '-h' ]];then USAGE exit 0fi###################### 对选项进行赋值 ###################while getopts ":u:p:h:d:" optname;docase "$optname" in"u") user=$OPTARG;; "p") passwd=$OPTARG ;;"h") host=$OPTARG ;;"d") db=$OPTARG;; ":") echo "此选项没有值!" ;;"*") echo "错误信息...";;"?") echo "不知道此选项...";;esacdone############# 对要备份的库进行判断并执行备份操作 ###############[ -d ${full_backupdir} ] || mkdir -p ${full_backupdir}cd ${full_backupdir}: > err.logif [ ${#db} -eq 0 ];then ${dump_cmd} -u${user} -p${passwd} -h${host} -A -F > ${today}.sql 2> err.log status=$? sqlname="${today}.sql"else ${dump_cmd} -u${user} -p${passwd} -h${host} --databases $db -F > ${today}.${db}.sql 2> err.log status=$? sqlname="${today}.${db}.sql"fi############ 对备份状态进行判断 #####################if [ ${status} -eq 0 ];then tar zcf ${sqlname}.tar.gz ./${sqlname} rm -f ${sqlname}########### 如果失败,则发送报警邮件到指定邮箱 ################else echo "备份数据库失败,错误日志如上所示!!!" >> err.log mail -s "mysql backup" $email < err.logfi############ 删除二十天前的备份文件 ##############find . -type f -name "*.tar.gz" -mtime +20 -delete2、二进制增量备份脚本
#!/bin/bash####################### 定义初始值 #############################user='root'passwd='123.com'datadir="/usr/local/mysql/data"backupdir="/opt/database/dailybackup/"dump_cmd='/usr/local/mysql/bin/mysqlbinlog'[ -d ${backupdir} ] || mkdir -p ${backupdir} #判断备份文件存放路径是否存在cd ${datadir} #切换至mysql的数据存放路径sum=`cat bin_log.index | wc -l` #取得所有二进制日志文件总数/usr/local/mysql/bin/mysql -u${user} -p${passwd} -e "flush logs" &> /dev/null #在备份前刷新二进制日志文件nextnum=0 #定义一个初始值为0backupsum=0for file in `cat bin_log.index` #对所有二进制日志文件进行遍历do binlogname=`basename $file` #获取二进制日志文件名#如果当前备份的文件数目比总数小(新刷新的二进制文件不需要备份) if [ $nextnum -lt $sum ];then [ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname} #如果备份目录下不存在该二进制文件,则进行copy动作 let nextnum++ #对备份成功数量进行增加 fidoneecho "跳过最新二进制日志文件,备份完成!!!"
备份
文件
二进制
日志
脚本
数据
数据库
密码
总数
用户
路径
错误
增量
成功
主机
信息
动作
变量
如上
数目
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
深圳微信软件开发报价
时序数据库数据挖掘
购买腾讯云服务器
阿里云 如何导出数据库
数据库服务器更改系统时间
camera模组软件开发
代理服务器优化方向
分布式存储服务器有什么用
网络安全法未进行等保测评
1100w双冗余服务器电源
网络安全讲师课酬
论述网络安全的技术
市工商局联合网络安全应急演练
服务器怎么打开光驱
服务器安全证书登陆失败
重量级软件开发方法
台湾免备案服务器
复杂网络安全教育
服务器接管方式是什么
添加好友修改昵称数据库设计
网络安全的制作小卡片
3d游戏软件开发都有什么软件
巴彦县网络安全应急演练的通知
美技网络技术公众号
江苏网络时钟同步服务器配置
网络技术计划节点图
数据库运维内容
提交审核功能数据库
世界互联网大会 科技创新
会玩中未绑定服务器是什么意思