shitou's blog 

  • Home
  • About
  • Feed
  • 十人族
  • MIX BOY
  • 塌客

Category "linux"

25
Aug

MySQL Innodb备份

Rails默认的数据库表都是用的Innodb,MySQL对Innodb表的备份不同于MyISAM表,由于Innodb对事物等特性的支持所以不能用传统备份MyISAM表的方法来备份Innodb数据,MyISAM表数据的备份方式总结下有:

 

  • 使用mysqldump
  • 直接拷贝数据库目录
  • 把日志文件和定期制作的备份增量文件结合
  • 利用MySQL的镜像机制进行备份

 

其中直接拷贝数据库目录的方式不适用于Innodb表,而且mysqldump在对Innodb表进行数据备份时也必须加上特殊的参数,所以自己就写了一个shell脚本,用来备份Innodb表,并且压缩

 

#!/bin/bash
#author:        shitou
#date:            08/24/2008 13:52
#aim:            backup all innodb database and gzip it, for MySQL5.x

#params
MYSQL_USER='name'
MYSQL_PWD='passwd'
MYSQL_HOST='localhost'
#bin paths
MYSQL='/usr/bin/mysql'
MYSQLDUMP='/usr/bin/mysqldump'

#db to backup, separate by blank
DBS='friends faming shitoublog suzhousage bone'

#output directory
DEST='/root/script/mysql_innodb_backup'

NOW="$(date +%d-%m-%Y)"
[ ! -f $DEST ] &&  mkdir -p $DEST

TMP='tmp'
if [ -f $DEST/$TMP ]; then
    rm -rf $DEST/$TMP
else
    mkdir -p $DEST/$TMP
fi

for db in $DBS
do
$MYSQLDUMP -u$MYSQL_USER -p$MYSQL_PWD -h$MYSQL_HOST \
    --skip-opt  --single-transaction --add-drop-table --create-options --quick \ 
    --extended-insert --set-charset --disable-keys $db > $DEST/$TMP/$db-$NOW.sql
done

cd $DEST && tar zcvf mysql-$NOW.tar.gz $TMP > /dev/null
[ -d $TMP ] && rm -rf $TMP

 

定制参考脚本中的注释

 

Tags: shell,backup

2008-08-25 09:03:21, 11979 reviews, comment

send to mailbox

Your email:

Related Posts

Shell script to backup all MySQL database

【转载】命令的小总结

shell中的数组

一些shell技巧

( ),{ }的区别

一个小命令

awk同时操作两个文件

shell小技巧

Shell: 统计MySQL InnoDB表的大小

awk多维数组

继续凸墙 for Mac OS

json_formatter

TOP

Tags

json Impactjs Canvas fun gen_server superfly PS3 Webgame HTML5 jquery SSH tenerer MooseFS gearman-ruby Gearman MongoDB MochiChat TCP U-ka saegusa IN db command Mai Kuraki Norah Jones log iPhoneException ACG Mac Safari objective-c CouchDB LVS AJAX debian 推荐 AMQP google mail bug gettext Erlang 北京 iptables 架构 tips mysql backup function 我看 postfix 监控 SEO cache Etag memcache thread 进程 线程 无锡 yield file column mixboy xml rss gems ruby shitou shell lighttpd 安全 csrf 公司 nginx linux 模块 apache webserver 朋友 大学 生活 尼古拉斯凯奇 movie 文件同步 笑笑 歌词 auto complete plugin rails music ubuntu blog

Category

  • HTML5[3]
  • iPhone[17]
  • Erlang[11]
  • google[13]
  • 生活[45]
  • 音乐[13]
  • 电影[11]
  • linux[29]
  • web server[6]
  • mail server[3]
  • cluster[1]
  • system manage[9]
  • ruby[20]
  • ruby on rails[28]
  • 开源[4]

Episode

  • MongoDB
  • MochiChat
  • iPhoneException
  • shell
  • thread
  • memcache


Popular Posts

  • 准备开始学习Erlang了(恶狼, 二郎..)
  • Ruby遍历MemCached的key
  • 服务器监控小脚本
  • MySQL Innodb备份
  • [转载]5个有用的ruby gems

Recommended Posts

  • Tri-survive - HTML5 Game
  • Cut the rope - HTML5版
  • json_formatter
  • 在gen_server中spawn新的进程
  • Superfly - Wildflowers
  • 继续凸墙 for Mac OS
  • MongoDB Beijing 2011
  • MongoDB删除map_reduce生成的tmp collection
  • Mai Kuraki - Future Kiss
  • Erlang OOP
  • 用SSH tunnel凸墙
  • Google的语法高亮工具包
  • 大量数据的批量操作
  • 再次被和谐-_-
  • 十人族: 上线了

Friends' blogs

  • levy
  • sphance
  • andreas
  • yangkunlun
  • {:dev=>:wxianfeng}
  • bheye
  • joeydarko

Login

   注册

留言 查看留言

留言

   取消

留言 查看留言


Statistics

  • 访问次数: 316242
  • 今天访问: 37
  • 日志: 213
  • 评论: 4967
  • 音乐: 9
  • 用户: 1758


少女,不点下广告吗!

 

all by shitou

blog comments powered by Disqus

close