当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL数据库本地备份和双机相互备份

MYSQL
ext3下删除mysql数据库的数据恢复案例
mysql性能的检查和调优方法
数据库查询的分页优化技巧
如何才能有效对抗MySQL数据库的解密高手
mysql中从字段中URL提取域名信息
教你四种方法用来查看mysql版本
MySQL数据库数据备份和恢复详解
ubuntu下简单配置mysql数据库
MySQL数据库的root口令恢复方法总结
再谈 MySQL 数据库备份恢复和乱码问题
修改 Navicat 默认备份路径
MySQL数据库中修改密码及访问限制设置详解
小白讲座:在win下mysql备份恢复命令概括
菜鸟大讲堂:如何查看mysql版本的四种方法
扫盲大讲堂:mysql出错的代码解析及解答
MySQL安全大讲堂:MySQL数据库安全配置
怎样在vc、delphi中使用mysql(mysql odbc驱动的使用)
MySQL数据导入与导出之二
如何实现MySQL中的用户管理?
win 2000 安装 mysql-shareware-3.22.32-win

MYSQL 中的 MySQL数据库本地备份和双机相互备份


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 101 ::
收藏到网摘: n/a

MySQL的本地备份和双机相互备份脚本:

首先,我们需要修改脚本进行必要的配置,然后以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:[email protected]";">[email protected]";


fi


# Ended all backup opretion!


echo "";


echo "Note: if there is come wrong message white MySQL, you should check yourconfigure first!";


exit