网络编程
位置:首页>> 网络编程>> 数据库>> MySQL 自动备份与数据库被破坏后的恢复方法(3)

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

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

标签:mysql,备份,数据库

接下来,我们再次登录到MySQL服务器中,对测试用的数据库test进行一些修改,以便于测试数据恢复能否成功。

[root@sample ~]# 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 15 to server version: 4.1.20

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

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> update test set name='Shit,Windows';  ← 然后将test中表的值重新定义为“Shit,Windows”(原来为“Hello,CentOS”)

Query OK, 1 row affected (0.07 sec)

Rows matched: 1 Changed: 1 Warnings: 0

mysql> select * from test;  ← 确认test中的表被定义的值

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

| num | name  |

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

| 1 | Shit,Windows |  ← 确认已经将原test数据库表中的值修改为新的值“Shit,Windows”

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

1 row in set (0.00 sec)

mysql> exit  ← 退出MySQL服务器

Bye

以上,我们就等于模拟了数据库被篡改的过程。接下来,是数据库被“篡改”后,用备份进行恢复的方法。

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

然后,再次登录到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 16 to server version: 4.1.20

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

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> select * from test;  ← 查看数据库中的内容

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

| num | name  |

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

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

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

1 row in set (0.01 sec)

mysql> exit  ← 退出MySQL服务器

Bye

以上结果表示,数据库被修改后,用备份后的数据库成功的将数据恢复到了被“篡改”前的状态。

测试后…

测试完成后,将测试用过的遗留信息删除。

[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 19 to server version: 4.1.20

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

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> drop table test;  ← 删除test数据库中的表

Query OK, 0 rows affected (0.01 sec)

mysql> drop database test;  ← 删除测试用数据库test

Query OK, 0 rows affected (0.00 sec)

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

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

| Database |

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

| mysql |  ← 确认测试用数据库test不存在、已被删除

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

1 row in set (0.00 sec)

mysql> exit  ← 退出MySQL服务器

Bye

以上介绍了用我们自己建立的一段Shell脚本,通过mysqlhotcopy来备份数据库的方法。

对于许多个人爱好者来说,组建服务器可能不是很考虑数据被破坏以及数据被破坏后的恢复工作。但不能不说,对于服务器来说,数据破坏后的恢复效率也是区 别业余和专业的因素之一。所以笔者建议,在您配置好了Web服务器以及MySQL服务器等等的时候,千万不要急于应用它,而要想办法在有限的(硬件、软件)条件下使它“坚不可摧”之后,再考虑应用的问题。

而且,以上介绍的方法中提到的数据库自动备份脚本虽然被设置为每天定时运行,但当您运行某些与MySQL相关联的程序(论坛、社区等等)时,做一些可 能危及数据安全的操作的时候,运行数据库备份脚本即时备份当前状态数据库,也是非常有帮助的,至少可以在出现问题后保证数据库方面的可恢复性。

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com