`
zzc1684
  • 浏览: 1224483 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

Linux上自动备份MySQL

阅读更多
在数据库表丢失或损坏的情况下,备份你的数据库是很重要的。如果发生系统崩溃,你肯定想能够将你的表尽可能丢失最少的数据恢复到崩溃发生时的状态。本文主要对MyISAM表做备份恢复。

 

备份策略一:直接拷贝数据库文件

备份策略二:使用mysqldump备份数据库(一个星期全备一次,每天增量备份)

一、 直接拷贝数据文件

 

直接拷贝数据文件最为直接、快速、方便,但缺点是基本上不能实现增量备份。为了保证数据的一致性,需要在备份文件前,执行以下 SQL 语句:FLUSH TABLES WITH READ LOCK;也就是把内存中的数据都刷新到磁盘中,同时锁定数据表,以保证拷贝过程中不会有新的数据写入。这种方法备份出来的数据恢复也很简单,直接拷贝回原来的数据库目录下即可。

   为了方便的拷贝出数据文件,我写了一个脚本让其每天运行一次做备份。在/目录下建一个目录用来放置脚本文件,

#mkdir /scripts

创建一个备份数据库的一个脚本文件

#vi backup_mysql.sh

#!/bin/bash

backup_dir=/backup/databak   #备份文件放置目录

backup_target_dir=/backup/db

backup_logs_dir=/backup/logs   #备份日志目录

db=bcmedia

DATE=$(date +%Y%m%d)

#得到10天前的日期

ccDATE=$(date "-d 10 day ago" +%Y%m%d)

echo "开始复制数据表"  >> $backup_logs_dir/$db$DATE

echo "-----------`date +"%Y-%m-%d %H:%M:%S"`--------------------"  >> $backup_logs_dir/$db$DATE

cp -R /data/$db $backup_target_dir/   #mysql数据库的数据目录为/data

echo "开始压缩数据表"  >> $backup_logs_dir/$db$DATE

echo "------------------------"  >> $backup_logs_dir/$db$DATE

cd $backup_target_dir

tar -zcvf  $backup_dir/db$DATE.tar.gz $db/ >> $backup_logs_dir/$db$DATE

if [ $? -eq 0 ]

then

 echo "backup succeed" >> $backup_logs_dir/$db$DATE

else

 echo "backup fail" >> $backup_logs_dir/$db$DATE

fi

echo "开始删除原数据表"  >> $backup_logs_dir/$db$DATE

echo "-----------------------"  >> $backup_logs_dir/$db$DATE

rm -rf $backup_target_dir/* && echo “删除原数据表” >> $backup_logs_dir/$db$DATE

echo  "删除10天前数据" >>$backup_logs_dir/$db$DATE

if [ -e $backup_dir/db$ccDATE.tar.gz ]

then

 rm -rf $backup_dir/db$ccDATE.tar.gz

 echo "Delete $backup_dir/db$ccDATE.tar.gz succeed" >>$backup_logs_dir/$db$DATE

else

 echo "Not found $backup_dir/db$ccDATE.tar.gz file" >>$backup_logs_dir/$db$DATE

fi

if [ -e $backup_logs_dir/$db$ccDATE ]

then

 rm -rf $backup_logs_dir/$db$ccDATE

 echo "Delete $backup_logs_dir/$db$ccDATE succeed" >>$backup_logs_dir/$db$DATE

else

 echo "Not found $backup_logs_dir/$db$ccDATE file" >>$backup_logs_dir/$db$DATE

fi

 

保存退出并添加可执行的权限

#chmod 755 backup_mysql.sh

让脚本每天执行一次,每天备份一次数据库,在crontab 里面添加一行

Crontab –e

10 4 * * * /scripts/ backup_mysql.sh  #每天4点10分运行脚本备份数据库

      还原数据库的时候只要把备份出的文件拷贝到数据库放置数据的目录下,修改权限。重启下数据库就完成了恢复了。

 

二、 使用mysqldump备份数据库

 

          mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。关于mysqldump的更详细解释用/MysqlDir/bin/mysqldump –help 来查看详细的解释。

      我们使用的数据库备份完成之后有10个G如果每天都做一次全备,不方便,就一个星期做一次全备,一天做一次增量备份。为了不影响线上业务,实现在线备份,并且能增量备份,最好的办法就是采用主从复制机制(replication),在 slave 机器上做备份。详细的mysqlreplication请参看mysql主主、主从复制详解

    一个星期一次的全备的脚本,脚本文件放在/scripts目录下,备份时需要一些目录,注意需要手动创建。

 

#vi mysql_full_bak.sh

#!/bin/bash

# This is mysql mysqlfullbak scripts

#2009-08-20

#badboy

user=bak  

passwd=123456

databak_dir=/backup/cacti   #备份的目录

eMailFile=$databak_dir/email.txt

 

DATE=`date +%Y%m%d`

logFile=$databak_dir/logs/mysql$DATE.log

database=cacti

echo "     " > $eMailFile

echo "---------------------------------" >> $eMailFile

echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile

cd /data

dumpFile=$database$DATE.sql

GZDumpFile=$database$DATE.tar.gz

options="-u$user -p$passwd --opt --extended-insert=false --triggers=false -R --hex-blob --flush-logs --delete-master-logs -B $database"

mysqldump $options > $dumpFile  #导出数据文件

if [[ $? == 0 ]]; then

  tar cvzf $GZDumpFile $dumpFile >> $eMailFile 2>&1

  echo "BackupFileName:$GZDumpFile" >> $eMailFile

  echo "DataBase Backup Success" >> $eMailFile

  scp $GZDumpFile 地址”:/Dir   #传送备份文件到另一台计算机,需要做好ssh信任

  rm -f $dumpFile           #删除备份的文件

  rm –rf $databak_dir/daily/*  #删除每天备份的文件

else

  echo "DataBase Backup Fail!" >> $emailFile

  mail -s " DataBase Backup Fail " $eMail < $eMailFile  #如果备份不成功发送邮件通知

fi

echo "--------------------------------------------------------" >> $logFile

cat $eMailFile >> $logFile

更多mysqldump的选项请查看mysqldump –help

 

每天增量备份的脚本,定义为每天4点10分时运行此文件,备份上一天4点10分之后到今天4点之前的数据

#vi mysqldailybak.sh

#!/bin/bash

# This is mysql mysqldailybak scripts

# 2009-08-20

# badboy

/usr/bin/mysqladmin flush-logs   #

user=bak

passwd=123456

database=cacti

daily_databak_dir=$databak_dir/daily  #备份目录,需要创建

eMailFile=$daily_databak_dir/email.txt

 

DATE=`date +%Y%m%d`

logFile=$daily_databak_dir/mysql$DATE.log

echo "     " > $eMailFile

echo "---------------------------------" >> $eMailFile

echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile

echo "---------------------------------" >> $eMailFile

TIME=$(date "-d 10 day ago" +%Y%m%d%H%M%S)

StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")

echo “Delete 10 days before the log ” >> $eMailFile

mysql -u$user -p"$passwd" -e "purge master logs before ${TIME}" && echo "delete 10 days before log" |tee -a $eMailFile   #删除10天前的2进制文件

filename=/data/`cat /data/mysql-bin.index |awk -F "/" '{print $2}'`   # 2进制文件

for i in $filename

do

echo "$StartTime start backup binlog " >> $eMailFile

mysqlbinlog -u$user -p$passwd -d $batabase --start-datetime="$StartTime" $i >> $daily_databak_dir/daily$DATE |tee -a $eMailFile

done

if [ $? = 0 ]

then

 cd $daily_databak_dir

 tar -zcvf $daily_databak_dir/$database$DATE.tar.gz daily$DATE >>/dev/null 2>&1

 #scp $daily_databak_dir/$database$DATE.tar.gz 地址”:/Dir  #传送备份文件到另一台计算机,需要做好ssh信任

 echo "daily backup succeed" >> $eMailFile

else

 echo "daily backup fail" >> $eMailFile

 mail -s "MySQL Backup" $eMail < $eMailFile  #备份失败之后发送邮件通知

fi

cat $eMailFile > $logFile

添加可执行的权限                             

#chmod 755 /scripts/mysql_full_bak.sh /scripts/mysqldailybak.sh

加到crontab里面让脚本自动执行,如果有专门用于备份的服务器,可以利用ssh认证、scp命令,自动发送到另一台服务器上,保证数据的安全。可以参看rsync参数详解、利用ssh、rsync 实现数据的定时同步

 

#su –bak

#crontab –e

10 4 * * 1-6 /scripts/mysqldailybak.sh   #礼拜一到礼拜六运行每天备份脚本

10 4 * * 0 /scripts/mysql_full_bak.sh   #礼拜天执行全备份的脚本

 

如果想把备份之后的数据文件,传送到另一台服务器上,做好ssh信任之后把脚本中红色的哪行注释去掉就行。需要更多scp的资料请查看scp --help

 

分享到:
评论

相关推荐

    Linux下Mysql自动备份脚本

    Linux下自动备份Mysql文件shell脚本。

    如何在linux下实现mysql数据库每天自动备份 txt

    ### 如何在Linux下实现MySQL数据库每天自动备份 在Linux环境下进行MySQL数据库的日常自动备份是一项重要的维护工作,它能够确保数据的安全性与完整性。本文将详细介绍如何通过编写Shell脚本并结合Cron定时任务来...

    linux服务器定时自动备份mysql数据库的脚本sh

    利用 crontab -e 将此脚本加入即可,主要是用于linux服务器定时自动备份mysql数据库的脚本sh

    Linux上MySQL自动备份

    Linux上MySQL自动备份

    linux下 MYSQL 自动备份工具

    综上所述,"linux下 MYSQL 自动备份工具"是一个集成了`mysqldump`、`tar`和`cron`等工具的智能解决方案,它简化了数据库备份流程,确保了数据的安全和可靠性。通过编写和配置适当的shell脚本,如`backup.sh`,可以...

    linux mysql自动备份工具

    本篇文章将详细讲解如何在Linux系统中设置一个自动的MySQL备份工具,以便实现数据的自动备份,降低因系统故障或人为错误导致的数据丢失风险。 首先,我们需要了解备份MySQL数据库的基本原理。MySQL提供了多种备份...

    linux mysql自动备份

    mysql自动备份shell脚本,下载放到root下载etc/crontab中加入定时启动命令

    linux下mysql自动备份

    综上所述,Linux下MySQL的自动备份可以通过多种方式实现,选择哪种方法取决于你的具体需求,如备份速度、存储引擎类型以及资源限制。无论哪种方式,结合cron定时任务都能确保备份的定期执行,为数据库的安全提供保障...

    MySQL(Docker) 自动备份 Shell 脚本

    今天这个备份分二个版本一个是linux上直接安装的mysql,另一种是docker上安装的mysql。基本操作都一样只是备份sql语句不同而已。可以选择设置需要备份的库,自动备份压缩,自动删除 7 天前的备份,需要使用 crontab ...

    Linux平台Mysql自动备份脚本

    ### Linux平台Mysql自动备份脚本详解 #### 一、引言 在信息化时代,数据安全至关重要。数据库作为存储业务核心数据的关键组件,其稳定性和可靠性直接影响到整个系统的可用性。MySQL作为全球广泛使用的开源关系型...

    linux服务器如何每天定时的备份mysql

    本文将详细介绍如何通过编写Shell脚本并结合Cron定时任务,在Linux服务器上自动完成MySQL数据库的每日定时备份,并且只保留最近五天的备份文件。 #### 一、创建备份存储文件夹 首先,在Linux服务器上创建用于存储...

    Linux系统部署Mysql自动备份策略操作步骤(20200618).txt

    描述Linux系统部署Mysql自动备份操作详细步骤 描述Linux系统部署Mysql自动备份操作详细步骤 描述Linux系统部署Mysql自动备份操作详细步骤

    linux下自动备份数据库

    在Linux环境下,自动备份数据库是一项至关重要的任务,它确保了数据的安全性和业务的连续性。以下是一份详尽的步骤指南,教你如何在Linux系统中设置数据库的自动备份。 1. **选择数据库类型**:首先,你需要确定你...

    Linux下定时备份MySQL数据库的Shell脚本.pdf

    本文档介绍了一个用于在Linux环境下自动备份MySQL数据库的Shell脚本。通过利用Cron定时任务功能,该脚本能够在特定时间自动运行,完成数据库的备份操作。以下是该脚本的主要组成部分及功能说明: ##### 2.1 变量...

    linux自动备份mysql

    本文将详细介绍如何配置Linux下的MySQL自动备份。 首先,我们需要创建一个用于存放备份文件的目录。例如,在 `/www` 目录下创建一个名为 `backup` 的文件夹,可以使用以下命令: ```bash # cd /www # mkdir backup...

    Linux自动备份MySQL数据库的实用方法

    至此,Linux系统上的MySQL数据库已经配置好了自动备份。现在,系统会在设定的时间自动执行备份脚本,生成并压缩备份文件,有效降低了因数据丢失带来的风险。务必定期检查备份过程是否正常,并确保备份文件的安全存储...

    Linux自动备份MYSQL方法.pdf

    本文将详细介绍如何在Linux环境下设置自动备份MySQL数据库的方法。 首先,我们需要了解备份的类型。MySQL数据库备份通常分为全备和增量/差异备份。全备是备份所有数据库或指定数据库的所有表,而增量/差异备份只...

    Linux自动备份MySQL数据库并上传到FTP服务器上shell脚本

    ### Linux自动备份MySQL数据库并上传到FTP服务器上Shell脚本详解 #### 一、脚本概述 本脚本主要用于在Linux环境下实现MySQL数据库的自动备份,并将备份文件上传至指定的FTP服务器。对于需要定期备份MySQL数据库的...

    linux mysql定时备份脚本

    通过以上步骤,你已经在Linux系统上成功设置了MySQL的自动备份。记得替换脚本中的环境变量,使其符合你的实际配置。定期备份能确保即使遇到硬件故障或意外数据丢失,也能快速恢复到正常状态,从而保护你的数据安全。

    linux和windows上备份Mysql数据库java代码

    本篇我们将聚焦于如何在Linux和Windows操作系统上使用Java编写代码来备份MySQL数据库。 首先,我们需要了解备份MySQL数据库的基本原理。通常,备份过程包括以下步骤: 1. **连接到数据库**:使用JDBC(Java ...

Global site tag (gtag.js) - Google Analytics