MySQL 自动备份与数据库被破坏后的恢复方法(2)

来源:asp之家 时间:2010-03-25 10:29:00 

[root@Centos ~]# /bin/cp -Rf /backup/mysql/test/ /var/lib/mysql/  ← 复制备份的数据库test到相应目录

[root@Centos ~]# chown -R mysql:mysql /var/lib/mysql/test/  ← 改变数据库test的归属为mysql

[root@Centos ~]# chmod 700 /var/lib/mysql/test/  ← 改变数据库目录属性为700

[root@Centos ~]# chmod 660 /var/lib/mysql/test/*  ← 改变数据库中数据的属性为660

然后,再次登录到MySQL服务器上,看是否已经成功恢复了数据库。

[root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器

Enter password:  ← 输入MySQL的root用户密码

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

Your MySQL connection id is 14 to server version: 4.1.20

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

mysql> show databases;  ← 查看当前存在的数据库

+-------------+

| Database |

+-------------+

| mysql |

| test  |  ← 确认刚刚被删除的test数据库已经成功被恢复回来!

+------------+

2 rows in set (0.00 sec)

mysql> use test  ← 连接到test数据库

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> show tables;  ← 查看test数据库中存在的表

+-------------------+

| Tables_in_test |

+-------------------+

| test  |

+-------------------+

1 row in set (0.00 sec)

mysql> select * from test;  ← 查看数据库中的内容

+------+---------------------+

| num | name  |

+------+---------------------+

| 1 | Hello,CentOS |  ← 确认数据表中的内容与删除前定义的“Hello,CentOS”一样!

+------+---------------------+

1 row in set (0.01 sec)

mysql> exit  ← 退出MySQL服务器

Bye

以上结果表示,数据库被删除后,用备份后的数据库成功的将数据恢复到了删除前的状态。

[2] 当数据库被修改后的恢复方法

数据库被修改,可能存在着多方面的原因,被入侵、以及相应程序存在Bug等等,这里不作详细介绍。这里将只介绍在数据库被修改后,如果恢复到被修改前状态的方法。

具体和上面所述的“数据库被删除后的恢复方法”相类似。这里,测试用数据库接着使用刚刚在前面用过的test。这里为了使刚刚接触数据库的朋友不至于理解混乱,我们再次登录到MySQL服务器上确认一下刚刚建立的测试用的数据库test的相关信息。

[root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器

Enter password:  ← 输入MySQL的root用户密码

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

Your MySQL connection id is 14 to server version: 4.1.20

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

mysql> show databases;  ← 查看当前存在的数据库

+-------------+

| Database |

+-------------+

| mysql |

| test  |

+------------+

2 rows in set (0.00 sec)

mysql> use test  ← 连接到test数据库

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> show tables;  ← 查看test数据库中存在的表

+-------------------+

| Tables_in_test |

+-------------------+

| test  |

+-------------------+

1 row in set (0.00 sec)

mysql> select * from test;  ← 查看数据库中的内容

+------+--------------------+

| num | name  |

+------+--------------------+

| 1 | Hello,CentOS|

+------+--------------------+

1 row in set (0.01 sec)

mysql> exit  ← 退出MySQL服务器

Bye

然后,我们再次运行数据库备份脚本,将当前状态的数据库,再做一次备份。

[root@CentOS ~]# cd  ← 回到脚本所在的root用户的根目录

[root@CentOS ~]# ./mysql-backup.sh  ← 运行脚本进行数据库备份

标签:mysql,备份,数据库
0
投稿

猜你喜欢

  • 用户体验的另一种认识

    2007-10-25 12:36:00
  • 如何使用ADO.NET连接数据库?

    2010-06-03 10:52:00
  • CSS:浮动清理另类方法

    2008-11-17 11:45:00
  • 为SWFUpload增加ASP版本的上传处理程序

    2011-04-28 08:01:00
  • asp fso创建与删除文件与文件夹

    2008-12-31 16:07:00
  • 如何提升JavaScript的运行速度(函数篇)

    2010-05-17 13:27:00
  • 能否推荐一个论坛用的数据库结构?

    2009-11-01 18:09:00
  • Js中的函数直接量

    2007-12-21 19:15:00
  • Mootools 1.2教程(16)——排序类和方法简介

    2008-12-10 14:18:00
  • MySQL Dump/Restore

    2010-10-14 13:49:00
  • 交互设计:简单

    2011-08-27 16:46:27
  • 注册表单的改进分解

    2008-05-31 17:19:00
  • oracle SQL命令大全

    2009-07-02 11:55:00
  • 困惹的A标签

    2007-12-04 12:36:00
  • excel导入到SQL Sever数据库

    2008-03-25 10:24:00
  • asp使用session防止网页频繁刷新

    2007-09-26 14:25:00
  • 浏览器右下角弹出提示窗口

    2008-10-30 12:37:00
  • css reset中的list-style:none

    2010-05-26 13:56:00
  • 如何调用SQL Server的存储过程?

    2009-11-15 20:15:00
  • Web前端应用十种常用技术

    2010-09-01 20:46:00
  • asp之家 网络编程 m.aspxhome.com