mysql备份单实例(一)shell

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167

一、脚本说明
1、需要备份2个库(mysqltest1 mysqltest)
2、开启4个进程
3、可以选择进行备份不压缩和备份压缩
4、可以对不需要的数据库剔除
5、backup用户在数据库里的权限
grant  select ,reload,super,lock tables,create view,show view on *.* to  'backup' @ 'localhost'  identified by  'backup' ;
flush privileges;
6、计划任务
00 00 * * *  cd  /opt/dbbak  &&  bash  mysqlback.sh mysqlbackupconf >>  /opt/dbbak/dbbackup .log 2>&1
7、会删除三天前的binlog
8、mysql版本5.5的
9、debian7.4 (3.2.54-2 x86_64)
 
二、具体脚本如下
cat  mysqlback.sh
#!/bin/bash
#--------------------------------------------------
#Author:jimmygong
#Email:jimmygong@taomee.com
#FileName:mysqlback.sh
#Function: 
#Version:1.0 
#Created:2015-06-29
#--------------------------------------------------
if  [[ $ # -ne 1 ]]
then
     echo  -e  "Usage:$0 mysqlbackupconf"
     exit  1
else
     config=$1
     if  [[ ! -f $config ]]
     then
         echo  -e  "Usage:$0 mysqlbackupconf"
         exit  1
     fi
fi
source  $config
dbname= ""
currdate=$( date  +%Y%m%d)
haveinnodb=0
localip=$( ifconfig  eth0| awk  '/inet addr:/' | awk  -F:  '{print $2}' | awk  -F " "  '{print $1}' )
function  purgebinlog ()
{
     purdate=` date  "+%F %T"  -- date = '3 day ago' `
     pur= "purge master logs before '$purdate'"
     echo  "$pur" |mysql -u "$dbuser"  -p "$dbpass"
}
function  redirectlog ()
{
     logfile=$logdir/${currdate}_${localip}_log
     mkdir  -p $logdir
     exec  1>$logfile
     exec  2>$logfile
}
function  checkdestdir ()
{
     destdir=$destdir/$currdate
     if  [[ ! -d $destdir ]]
     then
         mkdir  -p $destdir
     fi
}
function  runcommand ()
{
     comm =$1
     mysql -u "$dbuser"  -p "$dbpass"  -sNe  "$comm"
}
function  generateschema ()
{
     i=0
     result=`runcommand  'show databases' `
     for  db  in  $result
     do
         rv=` echo  $exclude| grep  -w -i $db`
         if  [[ -n  "$rv"  ]]
         then
             continue ;
         fi
         dbname[i]=$db
         let  i++
     done
}
function  guessengine ()
{
     innodb=`runcommand  'show engines' | grep  -i innodb| grep  -i  yes `
     if  [[ ! -z  "$innodb"  ]]
     then
         haveinnodb=1
     fi
}
function  dobackupsql ()
{
     db=$1
     destname=$destdir/$db.sql
     if  [[ $haveinnodb - eq  1 ]]
     then
         dumpcomm= "mysqldump --opt -u$dbuser -p$dbpass --single-transaction --databases"
     else
         dumpcomm= "mysqldump --opt -u$dbuser -p$dbpass --databases"
     fi
     $dumpcomm $db > $destname
}
function  dobackupgzip ()
{
     db=$1
     destname=$destdir/$db.sql.gz
     if  [[ $haveinnodb - eq  1 ]]
     then
         dumpcomm= "mysqldump --opt -u$dbuser -p$dbpass --single-transaction --databases"
     else
         dumpcomm= "mysqldump --opt -u$dbuser -p$dbpass --databases"
     fi
     $dumpcomm $db| gzip  > $destname
}
function  backup ()
{
     actioncommand=$1
     if  [[ $commpress - eq  1 ]]
     then
         actioncommand= "dobackupgzip"
     else
         actioncommand= "dobackupsql"
     fi
     echo  -en  "`date`\tBACKUP\t$db\n"    
     $actioncommand $db
}
function  backupalldb ()
{
     count=0
     for  db  in  ${dbname[@]}
     do
         backup $db &
         let  count+=1
         [[ $((count%$processnum)) - eq  0 ]] && wait
     done
     wait
     echo  "all backup done"
}
 
purgebinlog
redirectlog
checkdestdir
generateschema
guessengine
runcommand  "flush logs"
backupalldb
exit  0
 
三、具体配置信息
cat  mysqlbackupconf
dbuser= "backup"
dbpass= "backup"
exclude= 'mysql information_schema performance_schema'
destdir= /opt/dbbak
logdir= /opt/dbbak/log
commpress=1
processnum=4
 
四、备份后结果
1、root@10.131.172.202:~ # ll /opt/dbbak/20150629/
-rw-r--r-- 1 root root 4443602410 Jun 29 19:18 mysqltest1.sql.gz
-rw-r--r-- 1 root root 4443601959 Jun 29 19:19 mysqltest.sql.gz
 
2、root@10.131.172.202:~ # ll /opt/dbbak/log/
-rw-r--r-- 1 root root 109 Jun 29 19:19 20150629_10.131.172.202_log








本文转自 xdoujiang 51CTO博客,原文链接:http://blog.51cto.com/7938217/1669168,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
Shell Linux API
【Shell 命令集合 备份压缩 】Linux 解压缩文件 unzip命令 使用指南
【Shell 命令集合 备份压缩 】Linux 解压缩文件 unzip命令 使用指南
52 0
|
1月前
|
算法 Shell Linux
【Shell 命令集合 备份压缩 】Linux 处理lha格式 lha命令 使用指南
【Shell 命令集合 备份压缩 】Linux 处理lha格式 lha命令 使用指南
36 0
|
1月前
|
Shell Linux 编译器
【Shell 命令集合 备份压缩 】Linux 提取zip压缩文件的详细信息 zipinfo命令 使用指南
【Shell 命令集合 备份压缩 】Linux 提取zip压缩文件的详细信息 zipinfo命令 使用指南
34 0
|
1月前
|
存储 算法 Shell
【Shell 命令集合 备份压缩 】⭐⭐Linux 压缩和归档工具 zip命令 使用指南
【Shell 命令集合 备份压缩 】⭐⭐Linux 压缩和归档工具 zip命令 使用指南
35 0
|
1月前
|
存储 Shell Linux
【Shell 命令集合 备份压缩 】Linux 解码uuencode编码的文件 uudecode 命令 使用指南
【Shell 命令集合 备份压缩 】Linux 解码uuencode编码的文件 uudecode 命令 使用指南
31 0
|
1月前
|
存储 Shell Linux
【Shell 命令集合 备份压缩 】Linux 恢复由dump命令创建的备份文件 restore命令 使用指南
【Shell 命令集合 备份压缩 】Linux 恢复由dump命令创建的备份文件 restore命令 使用指南
34 0
|
14天前
|
SQL 存储 关系型数据库
mysql数据库备份与恢复
mysql数据库备份与恢复
|
1月前
|
存储 Shell Linux
【Shell 命令集合 备份压缩 】Linux 将二进制文件转换为ASCII码 uuencode命令 使用指南
【Shell 命令集合 备份压缩 】Linux 将二进制文件转换为ASCII码 uuencode命令 使用指南
32 0
|
1月前
|
算法 Shell Linux
【Shell 命令集合 备份压缩 】Linux 解压缩ARJ格式 unarj命令 使用指南
【Shell 命令集合 备份压缩 】Linux 解压缩ARJ格式 unarj命令 使用指南
27 0
|
1月前
|
存储 算法 Shell
【Shell 命令集合 备份压缩 】⭐⭐⭐Linux 解压缩 tar命令 使用指南
【Shell 命令集合 备份压缩 】⭐⭐⭐Linux 解压缩 tar命令 使用指南
29 0

热门文章

最新文章