|——好友说:有些知识就是石头,走上这条路就没法绕过,就是牙齿啃碎了也要把它啃下来。

——————————————————————————————————————————

针对当前备份做一个总结记忆:

当前策略是保存一个星期的全量备份,体积在几百M,已经相当大。随着数据量的增大并非长久之计。

|——备份出文件  mysqldump

#!/bin/bash
 
BACKDIR=/data/backupSql
 
if [ ! -d ${BACKDIR} ]
then
mkdir -p ${BACKDIR}
fi
 
cd ${BACKDIR}
DumpFile=`date +%F`.sql.gz
SevenDaysAgoFile=`date +%F -d "-7 days"`.sql.gz
 
/usr/local/services/mysql/bin/mysqldump -S /tmp/mysql5.sock -R --opt --all-databases --single-transaction  --flush-logs --master-data=2 | gzip > /${BACKDIR}/${DumpFile}
 
if [ $? -ne 0 ]
    then
    echo "############################################"
    echo "#Wanning : mysqldump commend running fail!!#"
    echo "############################################"
else
    rm -f ${SevenDaysAgoFile};
    echo "############################################"
    echo "#Ok : mysqldump commend running success!!#"
    echo "############################################"
fi
 
 

在备份中的这个几分钟或者几小时时间段内,数据库还是一直在不断的产生新数据,但是从mysqldump备份文件恢复数据会丢失掉从备份点开始的更新数据,

所以还需要结合mysqlbinlog二进制日志增量备份。确保my.ini或者my.cnf中包含下面的配置以启用二进制日志,或者

mysqld ---log-bin:

[mysqld]
log-bin=mysql-bin

mysqldump命令必须带上--flush-logs选项以生成新的二进制日志文件:

脚本中使用 --flush-logs --master-data=2

这样生成的增量二进制日志文件比如为mysql-bin.000003,那么恢复数据时如下:

shell> mysql -uroot -pPwd < backup_sunday_1_PM.sql

shell> mysqlbinlog mysql-bin.000003 | mysql -uroot -pPwd

http://www.cnblogs.com/feichexia/p/MysqlDataBackup.html  MySQL数据备份之mysqldump使用
 
http://www.cnblogs.com/baseCode/archive/2011/12/08/2281081.html mysql 5.5 mysqldump 原文翻译

 

--single-transaction 保持数据一致性的加锁设置

http://www.itpub.net/thread-1410940-1-1.html

 

|——使用备份出来的文件恢复数据库

http://www.blogjava.net/alpha/archive/2007/08/10/135694.html  MySQL的mysqldump工具的基本用法

 

|——恢复出来的数据报了几个错误:

mysql之导入错误----Cannot load from mysql.proc解决办法 http://blog.sina.com.cn/s/blog_888269b20100zv4t.html

mysql 1449 : The user specified as a definer ('root'@'%') does not exist 解决方法  http://hi.baidu.com/liyanqin2288/item/5de086da8c94ef3348e1dd59

 

|——填坑:

https://dev.mysql.com/doc/refman/5.1/en/mysqldump.html :4.5.4 mysqldump — A Database Backup Program

 

http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html  Mysql备份还原数据库之mysqldump实例及参数详细说明

 

http://www.imhdr.com/mysql/mysqldump-import-export-database-summarizes/  mysqldump导入导出数据库总结

 

 

|——改进版本

#!/bin/bash
#author:logonmy@126.com
#desc:
# 可以做到第一次全量备份,后面几天增量备份[待研究,这里是7天全量]
# AND the database Engine is innodb
 
BACKDIR=/data/backup
 
if [ ! -d ${BACKDIR} ]
then
mkdir -p ${BACKDIR}
fi
 
cd ${BACKDIR}
 
#每日生成新的备份DIR
DumpDir=${BACKDIR}/`date +%F`
 
FullDumpFile=full_`date +%F`.sql.gz
AddDumpFile=add_`date +%H`.sql.gz
 
if [ ! -d ${DumpDir} ]
then
mkdir -p ${DumpDir}
fi
 
#7天之前的备份DIR
SevenDaysAgoDir=`date +%F -d "-7 days"`
 
# Index="`grep log-bin /etc/my.cnf |awk -F'[=.]' '{print $2".index"}'|head -n 1`"
# binFileName=`tail -n1 $index`
 
mysqldump=/usr/local/services/mysql/bin/mysqldump
 
Sock=/tmp/mysql5.sock
Opt="-R --single-transaction --flush-logs --master-data=2"
 
DB="--databases vmeipai cpa"
 
# day=`date +%F`
# hour=`date +%H`
 
#-h$host -u$user -p$passwd 本来命令后面要跟这样的参数,这里默认root所以没有使用。
#host=localhost
#user=root
#passwd=
 
#全量
dumpFull()
{
    ${mysqldump} -S ${Sock} ${opt} ${DB} | gzip > ${DumpDir}/${FullDumpFile}
}
 
#删除7天以前的备份
delSevenAgo()
{
    [ -d ${BACKDIR}/${SevenDaysAgoDir} ] && rm -rf ${BACKDIR}/${SevenDaysAgoDir}; 
}
 
dumpFull
 
if [ $? -ne 0 ]
    then
    echo "############################################"
    echo "#Wanning : mysqldump commend running fail!!#"
    echo "############################################"
else
    delSevenAgo
 
    echo "############################################"
    echo "#Ok : mysqldump commend running success!!#"
    echo "############################################"
fi

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

 

参考:

http://hi.baidu.com/xingxuejun/item/290772760302d411d1dcb349 mysql完全备份+增量备份脚本

http://hi.baidu.com/urzalknsyzchrur/item/c15e9392a72fbbbfcc80e5eb 在MySQL中使用更新日志文件

http://www.linuxidc.com/Linux/2012-07/66138.htm      MySQL不能启动 mysql-bin.index' not found

数据库备份mysqldump的更多相关文章

  1. MySQL数据库备份--mysqldump用法

    导出要用到MySQL的mysqldump工具,基本用法是:   shell> mysqldump [OPTIONS] database [tables] 如果你不给定任何表,整个数据库将被导出. ...

  2. mysql数据库备份 mysqldump

    一.--all-databases /application/mysql3307/bin/mysqldump -uroot -S /application/mysql3307/logs/mysql.s ...

  3. MYSQL之视图、触发器、存储过程、函数、事物、数据库锁和数据库备份

    一.视图 -- view 视图:是一个虚报表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据. 视图有如下特点: 1.视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系 ...

  4. MySQL之 视图,触发器,存储过程,函数,事物,数据库锁,数据库备份

    1.视图 视图: 是一个虚拟表,其内容由查询定义: 视图有如下特点;  1. 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系.  2. 视图是由基本表(实表)产生的表(虚表).  3. ...

  5. mysql数据库备份和恢复

    1.数据库备份 mysqldump -uroot -proot jira736 > jira736.sql 2.数据库恢复 mysql -uroot -proot jira762 < ji ...

  6. Linux MySQL数据库文件同步及数据库备份

    Mysql数据库链接 mysql -uroot -p -hdatacenter.jiaofukeyan.com -P33069 1.文件同步 rsync -avz --delete root@(需要同 ...

  7. Mysql基础(六):索引、数据库备份、锁和事务、慢查询优化、索引命中相关

    目录 数据库05 /索引.数据库备份.锁和事务.慢查询优化.索引命中相关 1. 什么是索引 2. 索引的原理 3. 索引的数据结构(聚集索引.辅助索引) 4. 索引操作 5. 索引的两大类型hash与 ...

  8. 【摘】Mysql备份还原数据库之mysqldump实例及参数详细说明

    原文http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html   我们在运营项目的过程中肯定会遇到备份数据库,还原数据库的情况,我们一 ...

  9. Mysql备份还原数据库之mysqldump实例及参数详细说明

    [root@localhost myexport]# mysqldump -h211.100.75.204 -uroot -p@^#coopen -P5029 --single-transaction ...

随机推荐

  1. mysql参数及解释

    key_buffer_size:(global.Dynamic)#*** MyISAM 特有的选项.即使你不使用 MyISAM 表,你仍应该将它设置为 8-64M,因为它也被用于内部的临时磁盘表.这个 ...

  2. 使用commons-pool2改造APNs连接池

    最近公司很多人反应apns推送的消息很慢,有时候需要5.6分钟才收到消息,我检查了下日志发现确实存在这个问题. 我们使用的是 https://github.com/relayrides/pushy 这 ...

  3. 2017 ACM/ICPC Asia Regional Shenyang Online array array array

    2017-09-15 21:05:41 writer:pprp 给出一个序列问能否去掉k的数之后使得整个序列不是递增也不是递减的 先求出LIS,然后倒序求出最长递减子序列长度,然后判断去k的数后长度是 ...

  4. Codeforces Round #414 C. Naming Company

    http://codeforces.com/contest/794/problem/C 题意: 有两个人要为公司起名字,每个人手中都有n个字符,现在要取一个n个字符长度的公司名.两人轮流取名,每次选择 ...

  5. 'webpack' 不是内部或外部命令解决办法以及npm配置

    昨天在笔记本上安装webpack,按照教程下来,使用webpack命令行,报错:'webpack' 不是内部或外部命令,也不是可运行的程序 或批处理文件.网上有大量的配置方法与解决办法,找了好久才成功 ...

  6. 如何实现蓝牙空中升级BLE OTA

    如何实现BLE OTA?什么叫DFU?如何通过UART实现固件升级?又如何通过USB实现固件升级?怎么保证升级的安全性?什么叫双备份(dual bank)DFU?什么叫单备份(single bank) ...

  7. PHP中用下划线开头的含义

    命名的规则 加一个为私有的 加两个一般都是系统默认的,系统预定义的,即所谓:=====================“魔术方法”与“魔术常量”=====================★PHP起止为 ...

  8. [Vue]组件——通过$emit为组件自定义事件

    1.在定义组件时调用内建的 $emit 方法并传入事件的名字,来向父级组件触发一个事件enlarge-text: Vue.component('blog-post', { props: ['post' ...

  9. Oracle Procedure记录

    1.定义 所谓存储过程(Procedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过 编译后存储在数据库系统中.在使用时候,用户通过指定已经定义的存储过程名字并给出相应的存储 ...

  10. VS2017编译项目出现提示al.exe运行失败的解决方法

    VS2013中编译一切正常,用VS2017打开项目,某个类库出现al.exe运行失败的解决方法,事件查看器中这样描述 “C:\Program Files (x86)\Microsoft SDKs\Wi ...