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

  • A+
所属分类:数据库技术

[2] 当数据库被修改后的恢复方法
数据库被修改,可能存在着多方面的原因,被入侵、以及相应程序存在Bug等等,这里不作详细介绍。这里将只介绍在数据库被修改后,如果恢复到被修改前状态的方法。
具体和上面所述的“数据库被删除后的恢复方法”相类似。这里,测试用数据库接着使用刚刚在前面用过的test。这里为了使刚刚接触数据库的朋友不至于理解混乱,我们再次登录到MySQL服务器上确认一下刚刚建立的测试用的数据库test的相关信息。

  1. [root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器
  2. Enter password:  ← 输入MySQL的root用户密码
  3. Welcome to the MySQL monitor. Commands end with ; or \g.
  4. Your MySQL connection id is 14 to server version: 4.1.20
  5. Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
  6. mysql> show databases;  ← 查看当前存在的数据库
  7. +-------------+
  8. | Database |
  9. +-------------+
  10. | mysql |
  11. | test  |
  12. +------------+
  13. 2 rows in set (0.00 sec)
  14. mysql> use test  ← 连接到test数据库
  15. Reading table information for completion of table and column names
  16. You can turn off this feature to get a quicker startup with -A
  17. Database changed
  18. mysql> show tables;  ← 查看test数据库中存在的表
  19. +-------------------+
  20. | Tables_in_test |
  21. +-------------------+
  22. | test  |
  23. +-------------------+
  24. 1 row in set (0.00 sec)
  25. mysql> select * from test;  ← 查看数据库中的内容
  26. +------+--------------------+
  27. | num | name  |
  28. +------+--------------------+
  29. 1 | Hello,CentOS|
  30. +------+--------------------+
  31. 1 row in set (0.01 sec)
  32. mysql> exit  ← 退出MySQL服务器
  33. Bye

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

  1. [root@CentOS ~]# cd  ← 回到脚本所在的root用户的根目录
  2. [root@CentOS ~]# ./mysql-backup.sh  ← 运行脚本进行数据库备份

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

  1. [root@sample ~]# mysql -u root -p  ← 用root登录到MySQL服务器
  2. Enter password:  ← 输入MySQL的root用户密码
  3. Welcome to the MySQL monitor. Commands end with ; or \g.
  4. Your MySQL connection id is 15 to server version: 4.1.20
  5. Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
  6. mysql> use test  ← 连接到test数据库
  7. Reading table information for completion of table and column names
  8. You can turn off this feature to get a quicker startup with -A
  9. Database changed
  10. mysql> update test set name='Shit,Windows';  ← 然后将test中表的值重新定义为“Shit,Windows”(原来为“Hello,CentOS”)
  11. Query OK, 1 row affected (0.07 sec)
  12. Rows matched: 1 Changed: 1 Warnings: 0
  13. mysql> select * from test;  ← 确认test中的表被定义的值
  14. +------+--------------------+
  15. | num | name  |
  16. +------+-------------------+
  17. 1 | Shit,Windows |  ← 确认已经将原test数据库表中的值修改为新的值“Shit,Windows”
  18. +------+-------------------+
  19. 1 row in set (0.00 sec)
  20. mysql> exit  ← 退出MySQL服务器
  21. Bye

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

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

然后,再次登录到MySQL服务器上,看数据库是否被恢复到了被“篡改”之前的状态。

  1. [root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器
  2. Enter password:  ← 输入MySQL的root用户密码
  3. Welcome to the MySQL monitor. Commands end with ; or \g.
  4. Your MySQL connection id is 16 to server version: 4.1.20
  5. Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
  6. mysql> use test  ← 连接到test数据库
  7. Reading table information for completion of table and column names
  8. You can turn off this feature to get a quicker startup with -A
  9. Database changed
  10. mysql> select * from test;  ← 查看数据库中的内容
  11. +------+----------------+
  12. | num | name  |
  13. +------+----------------+
  14. 1| Hello,CentOS | ← 确认数据表中的内容与被修改前定义的“Hello,CentOS”一样!
  15. +------+----------------+
  16. 1 row in set (0.01 sec)
  17. mysql> exit  ← 退出MySQL服务器
  18. Bye

以上结果表示,数据库被修改后,用备份后的数据库成功的将数据恢复到了被“篡改”前的状态。
测试后…
测试完成后,将测试用过的遗留信息删除。

  1. [root@CentOS ~]# mysql -u root -p  ← 用root登录到MySQL服务器
  2. Enter password:  ← 输入MySQL的root用户密码
  3. Welcome to the MySQL monitor. Commands end with ; or \g.
  4. Your MySQL connection id is 19 to server version: 4.1.20
  5. Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
  6. mysql> use test  ← 连接到test数据库
  7. Reading table information for completion of table and column names
  8. You can turn off this feature to get a quicker startup with -A
  9. Database changed
  10. mysql> drop table test;  ← 删除test数据库中的表
  11. Query OK, 0 rows affected (0.01 sec)
  12. mysql> drop database test;  ← 删除测试用数据库test
  13. Query OK, 0 rows affected (0.00 sec)
  14. mysql> show databases;  ← 查看当前存在的数据库
  15. +-------------+
  16. | Database |
  17. +-------------+
  18. | mysql |  ← 确认测试用数据库test不存在、已被删除
  19. +-------------+
  20. 1 row in set (0.00 sec)
  21. mysql> exit  ← 退出MySQL服务器
  22. Bye

以上介绍了用我们自己建立的一段Shell脚本,通过mysqlhotcopy来备份数据库的方法。
对于许多个人爱好者来说,组建服务器可能不是很考虑数据被破坏以及数据被破坏后的恢复工作。但不能不说,对于服务器来说,数据破坏后的恢复效率也是区 别业余和专业的因素之一。所以笔者建议,在您配置好了Web服务器以及MySQL服务器等等的时候,千万不要急于应用它,而要想办法在有限的(硬件、软件)条件下使它“坚不可摧”之后,再考虑应用的问题。
而且,以上介绍的方法中提到的数据库自动备份脚本虽然被设置为每天定时运行,但当您运行某些与MySQL相关联的程序(论坛、社区等等)时,做一些可 能危及数据安全的操作的时候,运行数据库备份脚本即时备份当前状态数据库,也是非常有帮助的,至少可以在出现问题后保证数据库方面的可恢复性。