千家信息网

mysql的备份脚本分享

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,本篇内容介绍了"mysql的备份脚本分享"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!#!/bin/
千家信息网最后更新 2025年01月20日mysql的备份脚本分享

本篇内容介绍了"mysql的备份脚本分享"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

#!/bin/bash##################################################################                                                               ##       Purpose: MySQL backups                                  ## This script does a full or incremental backup  ## The full is done via mysqldump## The incremental is done via flush-logs option  ## with mysqladmin##                                                               ##                The script is also setup to email if a         ##                failure occurs                                 ##                                                               ##       Assumptions:                                            ##               1. Database is in Binary Update Log mode        ##               2. The variables are set correctly              ####Usage:mysql_backup [full|incremental]####                                                               ####################################################################################################################################               INITILIAZE VARIABLES                            ################################################################### Set the mode, full|incremental# parameter is passed inMODE=$1# set the username to connect to mysql for the backupMYSQLUSER=backup# set the password to connect to mysql for the backupMYSQLUSERPW=password# set the Binary Update Logs PathBINLOGPATH=/mysql/logs/emds01/mysql# Set the binary Update Logs nameBINLOGNAME=viper2-bin# set the backup pathBACKUPPATH=/export/home/mysql/backups# set the email address for errors to be emailed toEMAIL_ADDR=shenandoah.speers@cicadacorp.com# set the log fileLOGFILE=$BACKUPPATH/logs/$HOSTNAME_$RUNDATE.log# set the error log fileLOGERR=$BACKUPPATH/logs/ERRORS_$HOSTNAME_$RUNDATE.log# set the number of days to keep the backupsDAYSTOKEEP=5# set Run dateRUNDATE=`date +%Y%m%d%s`# set hostnameHOSTNAME=`uname -n`##################################################################               GLOBAL FUNCTIONS                                ##################################################################copyBinlogs() {# copy binlogs to backup direcho "Copying binlogs"for FILE in `cat $BINLOGPATH/$BINLOGNAME.index`doSFILE=(${FILE/*//})echo "- binlog $SFILE"cp $FILE $BACKUPPATH/$SFILE_$RUNDATEgzip $BACKUPPATH/$SFILE_$RUNDATEdone}removeOldBackups() {# remove old backupsecho "Removing old backups greater then $DAYSTOKEEP days"find $BACKUPPATH -type f -mtime +$DAYSTOKEEP -name *.gz -print -exec rm {} ;find $BACKUPPATH/logs -type f -mtime +$DAYSTOKEEP -name *.log -print -exec rm {} ;}startlog() {# IO redirection for loggingtouch $LOGFILEexec 6>&1           # Link file descriptor #6 with stdout.# Saves stdout.exec > $LOGFILE     # stdout replaced with file $LOGFILE.touch $LOGERRexec 7>&2           # Link file descriptor #7 with stderr.# Saves stderr.exec 2> $LOGERR     # stderr replaced with file $LOGERR.}stoplog() {#Clean up IO redirectionexec 1>&6 6>&-      # Restore stdout and close file descriptor #6.exec 1>&7 7>&-      # Restore stdout and close file descriptor #7.}##################################################################               START OF MAIN                                   ##################################################################case "$MODE" in'full')# Daily backup# - copy all bin logs to backup directory# - remove old backups and logsstartlog;echo "Start Mysql Daily backup `date +%c`"mysqldump -u $MYSQLUSER -p$MYSQLUSERPW --single-transaction --flush-logs --master-data=2--all-databases --delete-master-logs | gzip > $BACKUPPATH/$HOSTNAME_full_$RUNDATE.sql.gzcopyBinlogs;removeOldBackups;echo "Finish Mysql Daily backup `date +%c`"stoplog;email;;;'incremental')# hourly backup# - flush logs# - copy all bin logs to backup directory if not already doneecho "Start Mysql hourly backup `date +%c`"startlog;mysqladmin -u $MYSQLUSER -p$MYSQLUSERPW flush-logscopyBinlogs;echo "Finish Mysql hourly backup `date +%c`"stoplog;;;*)echo "Usage: mysql_backup [full|incremental]";;esac# email any errors encounteredif [ -s "$LOGERR" ]thencat "$LOGERR" | mail -s "ERRORS REPORTED: MySQL Backup error Log for $HOSTNAME - $RUNDATE" $EMAIL_ADDRcat "$LOGFILE" | mail -s "MySQL Backup Log for $HOSTNAME - $RUNDATE" $EMAIL_ADDRSTATUS=1elseSTATUS=0fiexit $STATUS##################################################################               END OF MAIN                                     ##################################################################

"mysql的备份脚本分享"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

备份 脚本 内容 更多 知识 实用 学有所成 接下来 困境 实际 情况 文章 案例 编带 网站 行业 过程 高质量 学习 有关 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 如何构建网络安全框架体系 打开数据库cmd命令窗口 视频上传数据库安卓 软件开发用哪款笔记本好使 远程服务器管理工具错误 网络安全小报手抄报资料 多智能体软件开发 软件开发 涉密资质证书 海南省软件开发 mysql服务器登录 华为服务器v5主板价格 天津常规软件开发质量服务 盘古计算机软件开发有限公司 win10组建数据服务器 研究生软件开发专业介绍 电脑服务器反回数据解析失败 网络安全法立法宗旨 买本地硬盘还是云服务器 华为电信软件开发 专科计算机网络技术课程推荐 为什么服务器硬盘强调安全 notes修改数据库服务器 娄底网络安全应急指挥中心 以色列网络安全系数 安全管理数据库的方法 西安现代化安全文化展厅软件开发 计算机软件开发书 网络安全等级保护是什么工作 青浦区专业软件开发价格表格 怎样关闭服务器停止运行
0