MySQL数据库如何用脚本备份全库和增量备份
发表于:2024-11-22 作者:千家信息网编辑
千家信息网最后更新 2024年11月22日,MySQL数据库如何用脚本备份全库和增量备份?针对这个问题,今天小编总结这篇有关数据库备份的文章,可供感兴趣的小伙伴们参考借鉴,希望对大家有所帮助。1、全库备份脚本如下:#!/bin/bash####
千家信息网最后更新 2024年11月22日MySQL数据库如何用脚本备份全库和增量备份
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 -delete
2、二进制增量备份脚本
#!/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 "跳过最新二进制日志文件,备份完成!!!"
以上就是MySQL数据库用脚本备份全库和增量备份的具体实现方法,看完之后是否有所收获呢?如果想了解更多相关内容,欢迎关注行业资讯!
备份
文件
二进制
数据
脚本
日志
数据库
增量
密码
总数
用户
路径
错误
成功
主机
信息
兴趣
内容
动作
变量
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
固件软件开发工程师
服务器搭建游戏要什么配置
奥巴马的网络安全演讲稿
淄川hr人力资源软件开发公司
阿里云服务器管理器配置
数据库排名语句
spring 配置数据库
方块方舟进服务器崩溃
sgh数据库
干部网络安全专题培训心得体会
北邮网络安全博士就业前景
档案专题数据库的分类
什么是综合信息数据库系统
手机如何保护网络安全
公司服务器会设置监控吗
外文数据库比较
商丘软件开发
taptap的原神是什么服务器
山西计算机网络技术升本考试科目
边缘服务器多级管理
qpm 软件开发
审计数据库采集
湖南教育考试院高考录取数据库
附近服务器搬迁报价表
渭源网络安全宣传片
虚拟机打印服务器配置与管理
软件开发行业年终总结
学校网络安全设备招标
网络安全系统分析师
eve服务器是什么意思