首 页
网站案例
虚拟主机
企业邮箱
域名注册
Flash制作
软件开发
广告设计
服务报价
激情唯诚
联系我们
公告:热烈庆祝南京唯诚 网络2010版官方网站改版成 功!
 
MySQL数据库的应用    (3)
时间:2010-06-12 11:02 来源:南京网站建设        点击:
TAG:
 

[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服务器中,对测试 用的数据库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相关联的程序(论 坛、社区等等)时,做一些可 能危及数据安全的 操作的时候,运行数据库备份脚本即时备份当前状态数据库,也是非常有帮助的,至少可以在出现问题后保证数据库方面的可恢复性。

(责任编辑: admin)
 
 
上一篇:MySQL数据库的应用    (2)
下一篇:sql2000如何完美压缩 .mdf文件
 


 推荐关注

 热点关注

关于我们 | 工作机会 | 付款方式 | 网站制作 | 网页制作 | 网页设计 | 网络公司 | 联系我们 | 网站地图
版权所有:南京唯诚信息技术 有限公司 © 2005-2010 All Rights Reserved.
咨询专线: 400-657-0669 技术专线: 025-83208669-808 传真:025-83208669-803
地址:南京市鼓楼区广州 路37-1号江苏科技大厦 502室 邮编:210008 苏ICP备05002558号
友情链接: