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

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

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

标签:mysql,备份,数据库

[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  ← 运行脚本进行数据库备份

0
投稿

猜你喜欢

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