数据库教程:MySQL 自动备份与数据库被破坏后的恢复方法第1/2页分享

一、前言:

当数据库服务器建立好以后,我们首先要做的不是考虑要在这个支持数据库的服务器运行哪些受MySQL提携的程序,而是当数据库遭到破坏后,怎样安然恢复到最后一次正常的状态,使得数据的损失达到最小。

或者说,仅仅是数据库服务器的建立,只能说明它能做些什么,并不代表它能稳定的做些什么。灾难恢复的效率及全面性,也是系统的稳定性的一个准因素,尤其对于一个服务器系统。

这一节,介绍数据库自动备份以及数据库被破坏后的恢复的方法。在这里,我们使用mysqlhotcopy,并且定义一段Shell脚本来实现数据库的自动备份,并且,让整个数据自动备份与数据恢复过程都基于Shell。

建立数据库备份所需条件

[1]建立自动备份脚本

在这里,为了使数据库备份和恢复的符合我们的实际要求,用一段符合要求的Shell脚本来实现整个备份过程的自动化。

[root@CentOS~]#vimysql-backup.sh ←建立数据库自动备份脚本,如下:
#!/bin/bash
PATH=/usr/local/sbin:/usr/bin:/bin
#TheDirectoryofBackup
BACKDIR=/backup/mysql
#ThePasswordofMySQL
ROOTPASS=******** 此处请将星号替换成MySQL的root密码
#RemaketheDirectoryofBackup
rm-rf$BACKDIR
mkdir-p$BACKDIR
#GettheNameofDatabase
DBLIST=`ls-p/var/lib/mysql|grep/|tr-d/`
#BackupwithDatabase
fordbnamein$DBLIST
do
mysqlhotcopy$dbname-uroot-p$ROOTPASS$BACKDIR|logger-tmysqlhotcopy
done

[2]运行数据库自动备份脚本

[root@CentOS~]#chmod700mysql-backup.sh 改变脚本属性,让其只能让root用户执行
[root@CentOS~]#./mysql-backup.sh 运行脚本
[root@CentOS~]#ls-l/backup/mysql/ 确认一下是否备份成功
total8
drwxr-x—2mysqlmysql4096Sep116:54mysql 已成功备份到/backup/mysql目录中

[3]让数据库备份脚本每天自动运行

[root@sample~]#crontab-e ←编辑自动运行规则(然后会出现编辑窗口,操作同vi)
0003***/root/mysql-backup.sh 添加这一行到文件中,让数据库备份每天凌晨3点进行

测试自动备份正常运转与否(备份恢复的方法)

这里,以通过实际操作的过程来介绍问题出现后的恢复方法。

[1]当数据库被删除后的恢复方法

首先建立一个测试用的数据库。

[root@CentOS~]#mysql-uroot-p ←用root登录到MySQL服务器
Enterpassword: ←输入MySQL的root用户密码
WelcometotheMySQLmonitor.Commandsendwith;org.
YourMySQLconnectionidis8toserverversion:4.1.20
Type’help;’or’h’forhelp.Type’c’toclearthebuffer.
mysql>createdatabasetest; ←建立一个测试用的数据库test
QueryOK,1rowaffected(0.00sec)
mysql>usetest ←连接到这个数据库
Databasechanged
mysql>createtabletest(numint,namevarchar(50)); ←在数据库中建立一个表
QueryOK,0rowsaffected(0.07sec)
mysql>insertintotestvalues(1,’Hello,CentOS’); ←插入一个值到这个表(这里以“Hello,CentOS”为例)
QueryOK,1rowaffected(0.02sec)
mysql>select*fromtest; ←查看数据库中的内容
+——+—————–+
|num|name|
+——+—————–+
|1 |Hello,Centos| ←确认刚刚插入到表中的值的存在
+——+——————+
1rowinset(0.01sec)
mysql>exit ←退出MySQL服务器
Bye

然后,运行刚才建立的数据库备份脚本,备份刚刚建立的测试用的数据库。

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

接下来,我们再次登录到MySQL服务器中,删除刚刚建立的测试用的数据库test,以便于测试数据恢复能否成功。

[root@Centos~]#mysql-uroot-p ←用root登录到MySQL服务器
Enterpassword: ←输入MySQL的root用户密码
WelcometotheMySQLmonitor.Commandsendwith;org.
YourMySQLconnectionidis13toserverversion:4.1.20
Type’help;’or’h’forhelp.Type’c’toclearthebuffer.
mysql>usetest ←连接到测试用的test数据库
Readingtableinformationforcompletionoftableandcolumnnames
Youcanturnoffthisfeaturetogetaquickerstartupwith-A
Databasechanged
mysql>droptabletest; ←删除数据中的表
QueryOK,0rowsaffected(0.04sec)
mysql>dropdatabasetest; ←删除测试用数据库test
QueryOK,0rowsaffected(0.01sec)
mysql>showdatabases;
+—————+
|Database|
+—————+
|mysql| ←确认测试用的test数据库已不存在、已被删除
+—————+
1rowinset(0.01sec)
mysql>exit ←退出MySQL服务器
Bye

上述就是数据库技术:MySQL 自动备份与数据库被破坏后的恢复方法第1/2页分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/910050.html

(0)
上一篇 2021年10月23日
下一篇 2021年10月23日

精彩推荐