【mysqldump备份指定数据库表】my_dump.sh

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

【mysqldump备份指定数据库表】my_dump.sh

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
#!/bin/bash
#
# 2015/6/8
# 根据指定的db.table,执行批量导出备份的任务,并归档到your_ip::bak上,发送邮件通知,最后再通知业务清理数据。
 
list_tables=(
t_a_201311
t_a_201312
t_b_201311
t_b_201312
t_c_201311
t_c_201312
t_d_201311
t_d_201312
t_e_201311
t_e_201312
)
 
 
function  dump_db_table() {
     local  d_db_base= '/data/app/mysql'
     local  s_datetime=$( date  +%Y%m%d_%H%M%S)
     local  s_port=3306
     local  s_password= 'xxx'
 
     local  s_db=$1
     if  [ -z ${s_port} ];  then
         echo  "Usage: $0 database table"
         exit  2;
     fi
 
     local  s_table=$2
     local  d_backup= "/home/backup/mysql/${s_port}/mysqldump/${s_db}"
     
     if  [ -z ${s_table} ];  then
         local  dump_args= "${d_db_base}/bin/mysqldump -h 127.0.0.1 -P ${s_port} -u root --password=${s_password} --hex-blob -R -E -e -q --triggers --default-character-set=latin1 ${s_db}"
         local  f_dump_tar= "${d_backup}/${s_datetime}-${s_db}.gz"
     else
         local  dump_args= "${d_db_base}/bin/mysqldump -h 127.0.0.1 -P ${s_port} -u root --password=${s_password} --hex-blob -R -E -e -q --triggers --default-character-set=latin1 ${s_db} ${s_table}"
         local  f_dump_tar= "${d_backup}/${s_datetime}-${s_table}.gz"
     fi
 
     test  -d ${d_backup} ||  mkdir  -p ${d_backup}
     echo  "[+] `date` Port: ${s_port} DB: ${s_db}.${s_table}"
 
     ${dump_args} | gzip  >${f_dump_tar}
 
     echo  "[-] `date` Saved to: ${f_dump_tar}"
     echo  "[-] `date` Done."
     echo
     sleep  1s
}
 
function  do_dump() {
     num_tables=${ #list_tables[@]}
     echo  "[numble of tables]: ${num_tables}"
     for  ((i=0;i<${num_tables};i++))
     do
         echo  "[${i}]导出表:${list_tables[$i]}"
         # 要执行真实操作时取消注释下面这1行
         #dump_db_table d_test2013 ${list_tables[$i]}
     done
}
 
function  do_bak() {
     do_dump
     #echo "[-] `date` rsync to your_ip::bak. Start."
     #rsync -avzP your_src_path your_ip::bak
     #echo "[-] `date` rsync to your_ip::bak. Done."
}
 
do_dump
# 要执行真实操作时取消注释下面这3行,并注释上面的这1行
#do_bak >/root/dump_db_table.log 2>&1
#rsync -avzP /root/dump_db_table.log your_ip::bak
#/usr/local/bin/python3 /usr/local/bin/mailman.py 'admin@company.com' '[backup] job done' "    ^.^ at `date`, backup some tables from d_test2013, now fininshed. Later on, I sent all tar.gz files to your_ip::bak by using rsync. (see log as attachement)" /root/dump_db_table.log



本文转自 pcnk 51CTO博客,原文链接:http://blog.51cto.com/nosmoking/1594800,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
关系型数据库 MySQL 数据库
Python tk dos命令备份mysql数据库
Python tk dos命令备份mysql数据库
24 0
|
3月前
|
数据库 数据安全/隐私保护 Python
写一个定时备份数据库的脚本,且只保留最近3天
写一个定时备份数据库的脚本,且只保留最近3天
67 3
|
3月前
|
存储 关系型数据库 MySQL
mysql数据库如何做到定期备份
mysql数据库如何做到定期备份
288 2
|
9天前
|
数据库
使用Navicat Premium 12进行数据库定期自动备份(定时任务)--图文详解
使用Navicat Premium 12进行数据库定期自动备份(定时任务)--图文详解
18 0
|
1月前
|
SQL 存储 数据库
数据安全无忧,SQL Server 2014数据库定时备份解密
数据安全无忧,SQL Server 2014数据库定时备份解密
|
2月前
|
关系型数据库 MySQL Linux
Linux环境下定时备份mysql数据库
Linux环境下定时备份mysql数据库
|
2月前
|
数据库 对象存储 数据安全/隐私保护
在oceanbase数据库中,有没有遇到备份到oss环境,备份进度到98%就一直卡着的问题?
在oceanbase数据库中,有没有遇到备份到oss环境,备份进度到98%就一直卡着的问题?
27 6
|
2月前
|
SQL 关系型数据库 MySQL
在OceanBase数据库中,mysqldump工具是可以用于数据备份的
【2月更文挑战第2天】在OceanBase数据库中,mysqldump工具是可以用于数据备份的
40 6
|
2月前
|
SQL 存储 关系型数据库
备份数据库
备份数据库
22 9
|
2月前
|
SQL 存储 算法
【数据库SQL server】数据库系统概述与DBS结构
【数据库SQL server】数据库系统概述与DBS结构
68 0
【数据库SQL server】数据库系统概述与DBS结构