Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1480882
  • 博文数量: 187
  • 博客积分: 10375
  • 博客等级: 上将
  • 技术积分: 3127
  • 用 户 组: 普通用户
  • 注册时间: 2006-03-07 10:58
文章分类

全部博文(187)

文章存档

2013年(1)

2012年(8)

2011年(28)

2010年(36)

2009年(47)

2008年(67)

我的朋友

分类: LINUX

2010-12-25 21:56:11

对于linux系统下的mysql DB的数据备份,以下两种方法,第一种方法是只备份数据,将数据保存在文本文件中;第二种方法是将整个DB备份,生成SQL文件,在DB恢复时较方便,当然,如果需要,也可以对个别表进行备份。

方法一:

#!/bin/bash

#DB服务器IP
DB_HOST="127.0.0.1"
#database name
DB_NAME="mysql"
#database username
DB_USER="USER"
#database password
DB_PASS="password"
#需要备份的表名
TBL_NAME_1=user
#需要备份的表名
TBL_NAME_2=db
#当前日期时间字符串 例:2010-12-20-10-12-30 (年月日时分秒)
DATE=`date +%Y-%m-%d-%H-%M-%S`
#执行mysql命令的参数
SQL_OPT="-u$DB_USER -p$DB_PASS -h $DB_HOST $DB_NAME"

/usr/bin/mysql $SQL_OPT << EOF
#将单个表的数据导出到文件中,
#FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n' 这些选项是把数据用逗号分隔,双引号引起来,换行用\n;如果不用,可以将这些选项删除。
select * from $TBL_NAME_1 into outfile "/tmp/bakfile/$TBL_NAME_1.$DATE.txt" FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n';
select * from $TBL_NAME_2 into outfile "/tmp/bakfile/$TBL_NAME_2.$DATE.txt" FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n';

quit
EOF

echo 'Backup success'


方法二:

#!/bin/bash


#DB服务器IP
DB_HOST="127.0.0.1"
#database name
DB_NAME="mysql"
#database username
DB_USER="
USER"
#database password
DB_PASS="
password"
#当前日期时间字符串 例:2010-12-20-10-12-30 (年月日时分秒)
DATE=`date +%Y-%m-%d-%H-%M-%S`
#bakup file absolute path
BAKUP_FILE=/tmp/bakfile/$DB_NAME-$DATE.sql

#执行mysqldump命令的参数
SQL_OPT="-u$DB_USER -p$DB_PASS -h $DB_HOST $DB_NAME"

#执行备份,整个DB所有表的备份,SQL语句的形式
/usr/bin/mysqldump --opt $SQL_OPT > $BAKUP_FILE

echo 'Backup success。'


阅读(4542) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~