通常情况下、mysql都需要备份,备份的方法有很多种。下面是我用脚本配合计划任务完成的自动备份远程的数据库。

  一、 确认备份方案:

  备份机:ip192.168.8.51

  数据库服务器:ip192.168.8.46

  备份的内容:对mysql的studydb、coursedb库进行远程备份、每天2:30执行,每个库备份为独立的sql文件。然后压缩为tar.gz格式,文件中嵌入备份的日期和时刻。

  1. 创建数据库:

 

[root@ns ~]# service mysqld status

  mysqld (pid 3554) 正在运行...

  [root@ns ~]# mysqladmin -uroot -p password 123123 ##更改密码

  Enter password: ##输入原密码

  [root@ns ~]# mysql -uroot -p123123

  Welcome to the MySQL monitor. Commands end with ; or \g.

  Your MySQL connection id is 8

  Server version: 5.0.77-log Source distribution

  Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

  mysql>

  mysql> create database studydb; ##创建数据库

  Query OK, 1 row affected (0.05 sec)

  mysql> create database couredb;

  Query OK, 1 row affected (0.00 sec)



  2. 给数据库赋权:

  mysql> grant select,lock tables on studydb.* to 'operator'@'192.168.8.51' identified by 'pwd123'; ##使用逻辑工具备份工具mysqldump是需要对库有select和lock tables的权限

Query OK, 0 rows affected (0.00 sec)

  mysql> grant select,lock tables on coursedb.* to 'operator'@'192.168.8.51' identified by 'pwd123';

  Query OK, 0 rows affected (0.00 sec)



  3. 在192.168.8.51测试备份:

 

[root@localhost ~]# cd /tmp

  [root@localhost tmp]# mysqldump -u operator -ppwd123 -h 192.168.8.46 --databases studydb >test.sql

  [root@localhost tmp]# ls

  bin games test.sql



  二、 在192.168.8.51编写Mysql备份脚本:

[root@localhost ~]# mkdir /root/bin

  [root@localhost ~]# cd /root/bin

  [root@localhost bin]# vi dbbak.sh

  #!/bin/bash

  #这是一个简单的mysql数据库逻辑备份脚本

  #1.定义数据库连接、目标库信息

  MY_USER="operator"

  MY_PASS="pwd123"

  MY_HOST="192.168.8.46"

  MY_CONN="-u $MY_USER -p$MY_PASS -h $MY_HOST"

  MY_DB1="studydb"

  MY_DB2="coursedb"

  #2.定义备份目录、工具、时间、文件名主体

  BF_DIR="/opt/dbbak/"

  BF_CMD="/usr/local/bin/mysqldump"

  BF_TIME=`date +%Y%m%d-%H%M`

  NAME_1="$MY_DB1-$BF_TIME"

  NAME_2="$MY_DB2-$BF_TIME"

  #3.先导出为.sql脚本,然后再进行压缩(打包后删除原文件)

  cd $BF_DIR/

  /bin/tar zcf $NAME_1.tar.gz $NAME_1.sql --remove &>/dev/null

  /bin/tar zcf $NAME_2.tar.gz $NAME_2.sql --remove &>/dev/null

  [root@localhost bin]# mkdir /opt/dbbak ###创建备份目录

  [root@localhost bin]# chmod a+x dbbak.sh ###给脚本执行权限

  [root@localhost bin]# dbbak.sh ##运行脚本

  [root@localhost bin]# ls /opt/dbbak/ ###验证效果

  coursedb-20130505-0311.tar.gz studydb-20130505-0311.tar.gz



  三、 在192.168.8.51上设置计划任务:

[root@localhost bin]# crontab -e

  30 2 * * * /root/bin/dbbak.sh

  [root@localhost bin]# chkconfig crond on

  [root@localhost bin]# service crond status

  crond (pid 3263) 正在运行...



  好了数据库备份这件事就搞定了。

 


一、实现本地自动备份数据库很简单:
1.以root身份登陆
2.计划任务(每天的3:30自动执行 /usr/bin/mysqlbackup)
crontab
0 3:30 * * * /usr/bin/mysqlbackup
3.写一个自动备份数据库脚本

vi /usr/bin/mysqlbackup 
                 
 #!/bin/bash 
                 
 mv /home/.../db_bak5.tgz /home/.../db_bak6.tgz 
                 
 mv /home/.../db_bak4.tgz /home/.../db_bak5.tgz 
                 
 mv /home/.../db_bak3.tgz /home/.../db_bak4.tgz 
                 
 mv /home/.../db_bak2.tgz /home/.../db_bak3.tgz 
                 
 mv /home/.../db_bak1.tgz /home/.../db_bak2.tgz 
                 
 rm -rf /home/.../db_bak.txt 
                 
 /usr/bin/mysqldump -uroot -ppassword dbname 
                 
 > /home/.../db_bak.txt 
                 
 cd /home/.../ 
                 
 tar czvf db_bak1.tgz db_bak.txt


二、这样每天的3:30就会在本地目录/home/.../下生成相应的数据库备份,开始由于/home/.../目录下缺少数据系统会提示错误,这是正常的
三、至于远程备份可以配合使用ftp或scp命令实现,方法很简单,查一下相关命令的使用,然后再改动一下mysqlbackup脚本就可以了


在win2003下MySQL数据库每天自动备份

终于让服务器每天早上备份一次 MySQL 数据库并自动打包,同时删除 5 天前的备份文件. 分享如下.

1. 环境: windows server 2003 + Apache 2.0 + PHP5 + MySQL 4.0.26 .

2. 假设 PHP 安装目录为 D:/php ,MySQL 安装目录为 D:/mysql.

3. 在 D:/php 下建立目录 WinRAR, 把你 winrar 安装目录下的 WinRAR.exe 和 RARReg.KEY 复制到 D:/php/WinRAR .

4. D:/php 下建立文件 mysql_backup.php:

/*/ 
                 
 #FileName: mysql_backup.php 
                 
 #Author: faisun 
                 
 #Website: http://www.softpure.com 
                 
 */ 
                 
 //保存目录,路径要用反斜杠.您需要手动建立它. 
                 
 $store_folder = 'D:\databse_backup'; 
                 
 //用户名和密码 
                 
 //该帐号须有操作[所有]的数据库及FILE的权限 
                 
 //否则有些数据库不能备份. 
                 
 $db_username = "root"; 
                 
 $db_password = ""; 
                 
 $time=time(); 
                 
 $nowdir = "$store_folder\\".date("Ymd",$time).""; 
                 
 if(file_exists("$nowdir.rar")) die("File exists.\n"); 
                 
 @mkdir($nowdir); 
                 
 mysql_connect("localhost","$db_username","$db_password"); 
                 
 $query=mysql_list_dbs(); 
                 
 while($result=mysql_fetch_array($query)){ 
                 
 system (dirname(__FILE__).'\..\mysql\bin\mysqldump --opt '."$result[Database] 
                 
 -u{$db_username} ".($db_password?"-p{$db_password}":"")." > 
                 
 $nowdir\\$result[Database].sql"); 
                 
 echo "dumping database `$result[Database]`...\n"; 
                 
 } 
                 
 echo "\nWinrar loading...\n"; 
                 
 system( dirname(__FILE__)."\\WinRAR\\WinRAR.exe a -ep1 -r -o+ -m5 -df \"$nowdir.rar\" 
                 
 "$nowdir\" " ); 
                 
 //删除 5 天前的文件 
                 
 @unlink("$store_folder\\".date("Ymd",$time-86400*5).".rar"); 
                 
 echo "\nOK!\n"; 
                 
 >



5. D:/php 下建立文件 mysql_backup.bat,内容只有一句:

php.exe mysql_backup.php

6. 双击该 bat 文件运行,如果能备份了,OK,下一步添加任务计划.

7. 把 D:/php/mysql_backup 添加到任务计划,时间选每天. 根据服务器的监测结果,每天早上 5-8 时为流量低峰期. 由于 5-7 时有些数据库的清理工作,可以把时间定在了早上 8 点整.

mysql的自动备份------这篇来自动网

time=`date +%G%I%d%H%M` #年月日时分

db=products 
                 
 echo "#产品库\r\n" >/sqlbak/${db}_$time.sql #备份文件名为[库名_年月日时分.sql] 
                 
 mysqldump --add-drop-table -c --allow-keywords --force --password=1234567890 --user=root $db >>/sqlbak/${db}_$time.sql 
                 


 db=news #另一个库 
                 
 echo "#新闻库\r\n" >/sqlbak/${db}_$time.sql 
                 
 mysqldump --add-drop-table -c --allow-keywords --force --password=1234567890 --user=root $db |bzip2 -9 >/sqlbak/${db}_$time.sql.bz2




#--add-drop-table是添加一个删出命令。
#-c是完整插入,每行插入都包括字段名
#--force是出错也继续
#--allow-keywords是对于保留字做字段名时对字段名加反引号。