Linuxoracle数据库的备份与恢复文档格式.docx
- 文档编号:21805367
- 上传时间:2023-02-01
- 格式:DOCX
- 页数:10
- 大小:20.35KB
Linuxoracle数据库的备份与恢复文档格式.docx
《Linuxoracle数据库的备份与恢复文档格式.docx》由会员分享,可在线阅读,更多相关《Linuxoracle数据库的备份与恢复文档格式.docx(10页珍藏版)》请在冰豆网上搜索。
oracle数据库的备份与恢复
原理及方法:
导出(备份)
exp用户名/密码@服务名file=d:
daochu.dmp(rows=no(导出空结构))
导入(恢复)
imp用户名/密码@服务名file=d:
daochu.dmpfromuser=原用户名touser=新用户名
----当我们使用一个数据库时,总希望数据库的内容是可靠的、正确的,但由于计算机系统的故障(包括机器故障、介质故障、误操作等),数据库有时也可能遭到破坏,这时如何尽快恢复数据就成为当务之急。
如果平时对数据库做了备份,那么此时恢复数据就显得很容易。
由此可见,做好数据库的备份是多么的重要,下面笔者就以oracle7为例,来讲述一下数据库的备份和恢复。
oracle数据库有三种标准的备份方法,它们分别为导出/导入(export/import)、冷备份、热备份。
导出备份是一种逻辑备份,冷备份和热备份是物理备份。
----一、导出/导入(export/import)
----利用export可将数据从数据库中提取出来,利用import则可将提取出来的数据送回oracle数据库中去。
----1.简单导出数据(export)和导入数据(import)
----oracle支持三种类型的输出:
----
(1)表方式(t方式),将指定表的数据导出。
----
(2)用户方式(u方式),将指定用户的所有对象及数据导出。
----(3)全库方式(full方式),将数据库中的所有对象导出。
----数据导出(import)的过程是数据导入(export)的逆过程,它们的数据流向不同。
----2.增量导出/导入
----增量导出是一种常用的数据备份方法,它只能对整个数据库来实施,并且必须作为system来导出。
在进行此种导出时,系统不要求回答任何问题。
导出文件名缺省为export.dmp,如果不希望自己的输出文件定名为export.dmp,必须在命令行中指出要用的文件名。
----增量导出包括三个类型:
----
(1)“完全”增量导出(complete)
----即备份整个数据库,比如:
----$expsystem/managerinctype=completefile=990702.dmp
----
(2)“增量型”增量导出
----备份上一次备份后改变的数据。
比如:
----$expsystem/managerinctype=incrementalfile=990702.dmp
----(3)“累计型”增量导出(cumulative)
----累计型导出方式只是导出自上次“完全”导出之后数据库中变化了的信息。
----$expsystem/managerinctype=cumulativefile=990702.dmp
----数据库管理员可以排定一个备份日程表,用数据导出的三个不同方式合理高效地完成。
----比如数据库的备份任务可作如下安排:
----星期一:
完全导出(a)
----星期二:
增量导出(b)
----星期三:
增量导出(c)
----星期四:
增量导出(d)
----星期五:
累计导出(e)
----星期六:
增量导出(f)
----星期日:
增量导出(g)
----如果在星期日,数据库遭到意外破坏,数据库管理员可按以下步骤来恢复数据库:
----第一步:
用命令createdatabase重新生成数据库结构;
----第二步:
创建一个足够大的附加回段。
----第三步:
完全增量导入a:
----$impsystem./managerinctype=rectorefull=yfile=a
----第四步:
累计增量导入e:
----$impsystem/managerinctype=rectorefull=yfile=e
----第五步:
最近增量导入f:
----$impsystem/managerinctype=restorefull=yfile=f
----二、冷备份
----冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库。
冷备份是将关键性文件拷贝到另外位置的一种说法。
对于备份oracle信息而言,冷备份是最快和最安全的方法。
冷备份的优点是:
----1.是非常快速的备份方法(只需拷贝文件)
----2.容易归档(简单拷贝即可)
----3.容易恢复到某个时间点上(只需将文件再拷贝回去)
----4.能与归档方法相结合,作数据库“最新状态”的恢复。
----5.低度维护,高度安全。
----但冷备份也有如下不足:
----1.单独使用时,只能提供到“某一时间点上”的恢复。
----2.在实施备份的全过程中,数据库必须要作备份而不能作其它工作。
也就是说,在冷备份过程中,数据库必须是关闭状态。
----3.若磁盘空间有限,只能拷贝到磁带等其它外部存储设备上,速度会很慢。
----4.不能按表或按用户恢复。
----如果可能的话(主要看效率),应将信息备份到磁盘上,然后启动数据库(使用户可以工作)并将所备份的信息拷贝到磁带上(拷贝的同时,数据库也可以工作)。
冷备份中必须拷贝的文件包括:
----1.所有数据文件
----2.所有控制文件
----3.所有联机redolog文件
----4.init.ora文件(可选)。
----值得注意的是冷备份必须在数据库关闭的情况下进行,当数据库处于打开状态时,执行数据库文件系统备份是无效的
----下面是做冷备份的完整例子:
----
(1)关闭数据库$sqldbalmode=y
----sqldba>
connectinternal;
shutdownnormal;
----
(2)用拷贝命令备份全部的时间文件、重做日志文件、控制文件、初始化参数文件
!
cp<
file>
<
;
backupdirectory>
----(3)重启oracle数据库
----$sqldbalmode=y
startup;
----三、热备份
----热备份是在数据库运行的情况下,采用archivelogmode方式备份数据的方法。
所以,如果你有昨天夜里的一个冷备份而且又有今天的热备份文件,在发生问题时,就可以利用这些资料恢复更多的信息。
热备份要求数据库在archivelog方式下操作,并需要大量的档案空间。
一旦数据库运行在archivelog状态下,就可以做备份了。
热备份的命令文件由三部分组成:
----1.数据文件一个表空间一个表空间地备份。
----
(1)设置表空间为备份状态
----
(2)备份表空间的数据文件
----(3)恢复表空间为正常状态
----2.备份归档log文件。
----
(1)临时停止归档进程
----
(2)log下那些在archiveredolog目标目录中的文件
----(3)重新启动archive进程
----(4)备份归档的redolog文件
----3.用alterdatabasebackupcontrolfile命令来备份拷贝文件
----热备份的优点是:
----1.可在表空间或数据文件级备份,备份时间短。
----2.备份时数据库仍可使用。
----3.可达到秒级恢复(恢复到某一时间点上)。
----4.可对几乎所有数据库实体作恢复。
----5.恢复是快速的,在大多数情况下在数据库仍工作时恢复。
----热备份的不足是:
----1.不能出错,否则后果严重。
----2.若热备份不成功,所得结果不可用于时间点的恢复。
----3.因难于维护,所以要特别仔细小心,不允许“以失败而告终”。
操作命令:
ORACLE数据库有两类备份方法。
第一类为物理备份,该方法实现数据库的完整恢复,但数据库必须运行在归挡模式下(业务数据库在非归挡模式下运行),且需要极大的外部存储设备,例如磁带库;
第二类备份方式为逻辑备份,业务数据库采用此种方式,此方法不需要数据库运行在归挡模式下,不但备份简单,而且可以不需要外部存储设备。
数据库逻辑备份方法
ORACLE数据库的逻辑备份分为三种模式:
表备份、用户备份和完全备份。
表模式
备份某个用户模式下指定的对象(表)。
业务数据库通常采用这种备份方式。
若备份到本地文件,使用如下命令:
expicdmain/icdrows=yindexes=ncompress=nbuffer=65536
feedback=100000volsize=0
file=exp_icdmain_csd_yyyymmdd.dmp
log=exp_icdmain_csd_yyyymmdd.log
tables=moninformation,icdmain.serviceinfo,icdmain.dealinfo
若直接备份到磁带设备,使用如下命令:
file=/dev/rmt0
注:
在磁盘空间允许的情况下,应先备份到本地服务器,然后再拷贝到磁带。
出于速度方面的考虑,尽量不要直接备份到磁带设备。
用户模式
备份某个用户模式下的所有对象。
expicdmain/icdowner=icdmainrows=yindexes=ncompress=nbuffer=65536
file=exp_icdmain_yyyymmdd.dmp
log=exp_icdmain_yyyymmdd.log
file=/dev/rmt0
如果磁盘有空间,建议备份到磁盘,然后再拷贝到磁带。
如果数据库数据量较小,可采用这种办法备份。
完全模式
备份完整的数据库。
业务数据库不采用这种备份方式。
备份命令为:
feedback=100000volsize=0full=y
file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)
log=exp_fulldb_yyyymmdd.log
对于数据库备份,建议采用增量备份,即只备份上一次备份以来更改的数据。
增量备份命令:
feedback=100000volsize=0full=yinctype=incremental
关于增量备份必须满足下列条件:
1.只对完整数据库备份有效,且第一次需要full=y参数,以后需要inctype=incremental参数。
2.用户必须有EXP_FULL_DATABASE的系统角色。
3.话务量较小时方可采用数据库备份。
4.如果磁盘有空间,建议备份到磁盘,然后再备份到磁带。
业务数据库备份方法及周期
用EXP进行备份前,先在SYS用户下运行CATEXP.SQL文件(如果以前已运行该文件,则不要执行这个脚本)。
没有特殊说明,不允许在客户端执行备份命令。
日结表数据备份
每月备份一次。
要备份的表为:
ALLSTAFFWORK_DAY_LOG
ALLSTAFFWORK_DAYLOG
AUTOCALLLOG_DAYLOG
LOCALZONE_DAYLOG
SERVICEINFO_DAYLOG
TELFEELOG_DAYLOG
TSHANDLEREPLY_DAYLOG
备份命令参照表模式下的备份命令。
业务相关表数据备份
每周一、四备份。
Commoninformation
ServiceInfo
DealInfo
AutoCallLog
AutoFaxLog
ServiceInfoAdd
TelFeeLog
从磁盘文件备份到磁带
如果首先备份到本地磁盘文件,则需要转储到磁带设备上。
1.若需查看主机上配置的磁带设备,使用如下命令:
lsdev-Cctape
显示的结果如下例所示:
rmt0Available30-58-00-2,0SCSI4mmTapeDrive
rmt1Defined30-58-00-0,0SCSI4mmTapeDrive
标明Available的设备是可用的磁带设备。
2.若需查看磁带存储的内容,使用如下命令:
tar-tvf/dev/rmt0
-rw-r--r--3004008089600Jan1114:
33:
572001exp_icdmain_20010111.dmp
如果显示类似如下内容,则表示该磁带存储的备份数据是从数据库直接备份到磁带上,而非从本地磁盘转储到磁带的备份文件,因此操作系统无法识别。
tar:
0511-193Anerroroccurredwhilereadingfromthemedia.
Thereisaninputoroutputerror.
或
0511-169Adirectorychecksumerroronmedia;
-267331077notequalto25626.
3.对于新磁带或无需保留现存数据的磁带,使用如下命令:
tar-cvf/dev/rmt0exp_icdmain_yyyymmdd.dmp
A.该命令将无条件覆盖磁带上的现存数据。
B.文件名不允许包含路径信息,如:
/backup/exp_icdmain_yyyymmdd.dmp。
4.对于需要保留现存数据的磁带,使用如下命令:
tar-rvf/dev/rmt0exp_icdmain_yyyymmdd.dmp
该命令将文件exp_icdmain_yyyymmdd.dmp追加到磁带的末端,不会覆盖现存的数据。
特别强调:
如果备份时是从数据库直接备份到磁带上,则不可再向该磁带上追加复制任何其他文件,否则该备份数据失效。
5.若需将转储到磁带上的备份文件复制到本地硬盘,使用如下命令:
A.将磁带上的全部文件复制到本地硬盘的当前目录
tar-xvf/dev/rmt0
B.将磁带上的指定文件复制到本地硬盘的当前目录
tar-xvf/dev/rmt0exp_icdmain_yyyymmdd.dmp
备份时间安排
由于备份时对系统I/O有较大影响,所以,建议在晚上11点以后进行备份工作。
业务数据库Oracle版本的恢复
恢复方案需根据备份方案确定。
由于业务数据库采用表备份和用户备份相结合的方案,所以业务数据库的恢复需根据实际情况采用表恢复和用户恢复相结合的方案。
恢复方案
数据库的逻辑恢复分为表恢复、用户恢复、完全恢复三种模式。
此方式将根据按照表模式备份的数据进行恢复。
A.恢复备份数据的全部内容
若从本地文件恢复,使用如下命令:
impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n
commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=exp_icdmain_csd_yyyymmdd.dmp
log=imp_icdmain_csd_yyyymmdd.log
若从磁带设备恢复,使用如下命令:
commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=/dev/rmt0
B.恢复备份数据中的指定表
tables=commoninformation,serviceinfo
commit=ybuffer=65536feedback=100000ignore=nvolsize=0
此方式将根据按照用户模式备份的数据进行恢复。
commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=exp_icdmain_yyyymmdd.dmp
log=imp_icdmain_yyyymmdd.log
commit=ybuffer=65536feedback=100000igno
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Linuxoracle 数据库 备份 恢复