新客网
首页 | 新闻 | 系统·网络·服务器·安全 | 工具·办公 | 编程·数据库 | 图象·网页·运营 | 硬件·存储 | 专题教程 | 论坛·old
 → 当前位置:首页 > 教程 > 数据库 > mysql > 正文

mysql的本地备份和双机相互备份脚本

XKER.COM   2006-10-11 8:49:35  来源:xker整理  点击:

  先修改脚本进行必要的配置,然后以root用户执行.
  1. 第一执行远程备份时先用 first参数.
  2. 本地备份用local参数
  3. 远程备份不用参数<注意1>
  
  注意:需要在另一主机上的Mysql用户用添加用户..
  
  需要配置的地方:
  # define host and mysql password
  REMOTE_HOST="" #远程主机名或IP
  REMOTE_PASSWORD="" #远程主机的mysql中的root@本地主机 密码.
  
  # define database path
  DB_PATH="/var/lib/mysql" #本地mysql数据库路径
  LOCAL_PASSWORD="" #本地mysql root用户密码
  DB_BACKUP_PATH="/root/db_bk" #本地备份时数据保存的路径
  
  NO_BACKUP_DB="" 设置本地数据库中不想备份的数据库名,用空格隔开
  
  直接下载
  #!/bin/sh
  # mysqldump_all.sh
  # this scripts is used to backup MySQL database bettwen tow MySQL SERVER!
  
  # define host and mysql password
  REMOTE_HOST=""
  REMOTE_PASSWORD=""
  
  # define database path
  DB_PATH="/var/lib/mysql"
  LOCAL_PASSWORD=""
  DB_BACKUP_PATH="/root/db_bk"
  
  # define which database no back up, write db anme escap whit space!
  # example;
  # NO_BACKUP_DB="yns test ps_note"
  # this said that if db name is "yns" or "test" or "ps_note", then not backup them!
  
  NO_BACKUP_DB=""
  
  # get the database name and process one by one
  echo "Start to Backup...";
  #ls /var/lib/mysql > /tmp/mydb.all
  if [ "$1" != "help" ]; then
  for db in `ls $DB_PATH`; do
  if_backup="1"
  if [ -d $DB_PATH/$db ] ; then
  for noBackDB in $NO_BACKUP_DB ; do
  if ( test "$db" = "$noBackDB" ); then
  #echo -n "...";
  if_backup="";
  fi
  done
  if [ $if_backup ]; then
  case "$1" in
  
  first)
  echo -n "Crate db [ $db ] on $REMOTE_HOST first!"
  result=`mysqladmin -h $REMOTE_HOST --password=$REMOTE_PASSWORD create $db`
  if [ ! $result ]; then
  echo "...Done!";
  else
  echo "...Fialed! check your configure plz!";
  echo "Remote host said: $result";
  exit
  fi
  ;;
  
  local)
  # back up to localhost dir.
  if [ ! -d $DB_BACKUP_PATH ]; then
  mkdir $DB_BACKUP_PATH
  fi
  echo -n "[ $db ]....Backup to local$DB_BACKUP_PATH with gzip";
  if [ -e "$DB_BACKUP_PATH/$db.gz" ]; then
  mv $DB_BACKUP_PATH/$db.gz $DB_BACKUP_PATH/$db.1.gz;
  fi
  mysqldump --password=Walte#Ming $db | gzip > $DB_BACKUP_PATH/$db.gz
  echo "...[OK]"
  ;;
  
  *)
  # Do common Backup!
  echo -n "[ $db ]...Do Backup! ====>> $REMOTE_HOST/$db";
  mysqldump --add-drop-table $db --password=$LOCAL_PASSWORD | mysql -h $REMOTE_HOST --password=$REMOTE_PASSWORD $db
  echo "....[OK]";
  esac
  else
  echo "[ $db ]";
  echo "***This database set to Not backup!...Operation CANCELED!";
  fi
  else
  echo "[ $db ]";
  echo "***Warning! Not a DataBbase. Backup Canceled***";
  fi
  done
  
  else
  echo "Usage: mysqldupm_all.sh [firs|local|help]";
  echo "Some question ask for href="mailto:walteyh@sohu.com";">walteyh@sohu.com";
  fi
  
  # Ended all backup opretion!
  echo "";
  echo "Note: if there is come wrong message white MySQL, you should check yourconfigure first!";
  exit
上一篇教程:MySQL数据导入导出方法与工具介绍三
下一篇教程:MySQL和Access的区别
收藏本文】 【我要投稿】 【打印本文】 【论坛讨论】 【关闭窗口

相关文章
·MySql中访问限制的设置方法·MySQL中修改密码方法总结
·MYSQL用户root密码为弱口令又一攻击方法·如何从SQL导入导出到MYSQL
·在服务器上安装使用MySQL的注意事项·MySql数据库备份
·如何让MySQL与OpenOffice结合使用 ·Mysql日期和时间函数
·为什么mysql5 改密码后不能登录?·Windows系统下升级PHP的MySQL客户端的方法
·MySQL和Access的区别·MySQL数据导入导出方法与工具介绍三
·MySQL数据导入导出方法与工具介绍二·MySQL数据导入导出方法与工具介绍一
·如何才能使图形化管理MySQL更轻松(二)·如何才能使图形化管理MySQL更轻松(一)

学院文章搜索
  
推荐文章
·史上最简单的Windows密码解
·用CSS实现动态显示的五角星
·MySQL数据导入导出方法与工
·从网络设置着手 教你四招让
·制作正式版优化大师绿色免
·编程过把瘾:自己动手写操
·数据恢复指南 专题
·硬盘“逻辑锁”解决办法
·DOS使用中的常见问题解答
·DOS下常用的相关网络命令
阅读排行
·免费代理IP(每日更新)
·ghost教程 专题
·流氓网站招招看 详细剖析恶
·轻松恢复硬盘数据 EasyRec
·DB2 9数据库专题
·克隆软件Ghost初级使用教程
·DOS下对系统重新进行分区
·DOS常用命令
·编程过把瘾:自己动手写操
·奇奇怪怪的QQ密技十五招
专题教程
·数据恢复指南 专题
·Web服务器专题
·DB2 9数据库专题
·ghost教程 专题
·局域网技术专题
·虚拟机专题
·CDN加速技术专题
·注册表教程专题
·电脑技巧 专题
·Linux与虚拟化技术
最新文章
·史上最简单的Windows密码解
·微软停止SP1更新 SP3年底将
·告别Win32,你准备好了吗?
·网页制作基础技巧 单选框和
·网页制作基础技巧 表单按钮
·MySql中访问限制的设置方法
·MySQL中修改密码方法总结
·MYSQL用户root密码为弱口令
·如何从SQL导入导出到MYSQL
·在服务器上安装使用MySQL的
设为首页 - 加入收藏 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2003 - 2006 XKER Inc. All Rights Reserved
新客网 版权所有