开发者社区> 技术小阿哥> 正文

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

简介:
+关注继续查看

【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,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【MySQL】Xtrabackup备份及恢复脚本
此备份脚本的策略是每周日和周三进去全备 其余每天增量备份。
330 0
使用Binlog日志恢复误删的MySQL数据
今天文章的主题是如何使用Mysql内置的Binlog日志对误删的数据进行恢复,读完本文,你能够了解到: MySQL的binlog日志是什么?通常是用来干什么的? 模拟一次误删数据的操作,并且使用binlog日志恢复误删的数据。
423 0
Mysql 通过frm&ibd 恢复数据
一次误操作,把数据库给搞乱了,innodb的数据库竟然无法直接恢复,还好找了一个文章,按文章进行,最后成功恢复。吓死我了,要是搞坏了,团队的人不背地骂死我了。 mysql存储在磁盘中,各种天灾人祸都会导致数据丢失。
2806 0
+关注
技术小阿哥
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载