mysql备份单实例(一)shell

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介:
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,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
208 10
|
7月前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
4月前
|
存储 关系型数据库 MySQL
【赵渝强老师】使用select...into outfile语句备份MySQL
本文介绍了MySQL中使用`SELECT...INTO OUTFILE`语句将表数据导出为文本文件的方法。通过示例演示了如何备份员工表(emp)的数据,包括创建存储目录、设置权限、配置参数`secure_file_priv`以及解决相关错误的过程。字段分隔符和行终止符可自定义,确保数据格式符合需求。最后展示了备份文件的内容,验证操作成功。
302 36
|
4月前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mysqldump备份MySQL
本文介绍了 MySQL 自带的逻辑备份工具 mysqldump 的使用方法。通过 mysqldump,可以将数据库中的数据转换为对应的 SQL 插入语句,便于备份和还原。文章详细说明了如何备份所有数据库、指定数据库及特定表,排除某些表不备份的操作,以及删除数据库后如何通过备份文件恢复数据。同时提供了视频讲解和具体命令示例,帮助用户更好地理解和应用该工具。
190 5
|
4月前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mydumper备份MySQL
本文介绍了使用mydumper工具进行MySQL数据库备份与恢复的操作方法。相比单线程工作的mysqldump,mydumper支持多线程,速度提升可达10倍。其功能包括事务性表快照、快速压缩、导出binlog等,并提供详细的参数说明和操作步骤。文章通过实例演示了安装mydumper、创建存储目录、全库备份、指定数据库及表备份、删除数据库以及使用myloader恢复数据的完整流程,并附带视频讲解,帮助用户更好地理解和应用该工具。
137 0
|
6月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
294 28
|
6月前
|
存储 关系型数据库 MySQL
利用Cron表达式实现MySQL数据库的定时备份
以上就是如何使用Cron表达式和mysqldump命令实现MySQL数据库的定时备份。这种方法的优点是简单易用,而且可以根据需要定制备份的时间和频率。但是,它也有一些限制,例如,它不能备份MySQL服务器的配置文件和用户账户信息,也不能实现增量备份。如果需要更复杂的备份策略,可能需要使用专门的备份工具或服务。
146 15
|
6月前
|
SQL Oracle 关系型数据库
在MySQL Shell里 重启MySQL 8.4实例
在MySQL Shell里 重启MySQL 8.4实例
174 2
|
SQL 关系型数据库 MySQL
mysql数据库备份shell
mysql数据库备份shell
118 0
|
关系型数据库 MySQL Shell
MySQL【实践 01】Linux 环境 MySQL 数据库备份 shell 脚本(脚本源码及说明+定时任务配置+数据库恢复测试)粘贴可以
MySQL【实践 01】Linux 环境 MySQL 数据库备份 shell 脚本(脚本源码及说明+定时任务配置+数据库恢复测试)粘贴可以
338 0

推荐镜像

更多
下一篇
oss教程