Linuxoracle数据库的备份与恢复.docx

上传人:b****6 文档编号:8669159 上传时间:2023-02-01 格式:DOCX 页数:10 大小:20.35KB
下载 相关 举报
Linuxoracle数据库的备份与恢复.docx_第1页
第1页 / 共10页
Linuxoracle数据库的备份与恢复.docx_第2页
第2页 / 共10页
Linuxoracle数据库的备份与恢复.docx_第3页
第3页 / 共10页
Linuxoracle数据库的备份与恢复.docx_第4页
第4页 / 共10页
Linuxoracle数据库的备份与恢复.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

Linuxoracle数据库的备份与恢复.docx

《Linuxoracle数据库的备份与恢复.docx》由会员分享,可在线阅读,更多相关《Linuxoracle数据库的备份与恢复.docx(10页珍藏版)》请在冰豆网上搜索。

Linuxoracle数据库的备份与恢复.docx

Linuxoracle数据库的备份与恢复

1数据库备份和恢复

(备份和恢复均已做成脚本自动运行,下列操作供参考,请不要在生产机上做测试)

1)数据库备份:

◆将dbexp.parm,dbexp.sh拷贝至/home/oracle/backup/.

以oracle用户登录系统

$cd/home/oracle/backup

$dos2unix*

$chmod755dbexp.sh

◆手工执行备份,用oracle用户登录:

$cd/home/oracle/backup

$./dbexp.sh

◆自动执行备份,用root用户登录:

#crontab-e

0001***su-oracle-c"/home/oracle/backup/dbexp.sh"

2)数据库恢复:

以oracle用户登录系统

◆删除用户:

sqlplus/nolog

>connect/assysdba;

>dropusercentercascade;

>createusercenteridentifiedbycenter;

>grantconnect,resource,dbatocenter

◆恢复数据库

$impcenter/centerfull=ygrants=yINDEXES=yconstraints=yLOG=/tmp/backup.logrows=yignore=yfile=xxx

(xxx--为以前备份的数据文件,如checkid_20041123.dat)

 

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;

----sqldba>shutdownnormal;

----

(2)用拷贝命令备份全部的时间文件、重做日志文件、控制文件、初始化参数文件

----sqldba>!

cp<;backupdirectory>

----(3)重启oracle数据库

----$sqldbalmode=y

----sqldba>connectinternal;

----sqldba>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

  若直接备份到磁带设备,使用如下命令:

  expicdmain/icdrows=yindexes=ncompress=nbuffer=65536

  feedback=100000volsize=0

  file=/dev/rmt0

  log=exp_icdmain_csd_yyyymmdd.log

  tables=moninformation,icdmain.serviceinfo,icdmain.dealinfo

  注:

在磁盘空间允许的情况下,应先备份到本地服务器,然后再拷贝到磁带。

出于速度方面的考虑,尽量不要直接备份到磁带设备。

  用户模式

  备份某个用户模式下的所有对象。

业务数据库通常采用这种备份方式。

  若备份到本地文件,使用如下命令:

  expicdmain/icdowner=icdmainrows=yindexes=ncompress=nbuffer=65536

  feedback=100000volsize=0

  file=exp_icdmain_yyyymmdd.dmp

  log=exp_icdmain_yyyymmdd.log

  若直接备份到磁带设备,使用如下命令:

  expicdmain/icdowner=icdmainrows=yindexes=ncompress=nbuffer=65536

  feedback=100000volsize=0

  file=/dev/rmt0

  log=exp_icdmain_yyyymmdd.log

  注:

如果磁盘有空间,建议备份到磁盘,然后再拷贝到磁带。

如果数据库数据量较小,可采用这种办法备份。

  完全模式

  备份完整的数据库。

业务数据库不采用这种备份方式。

备份命令为:

  expicdmain/icdrows=yindexes=ncompress=nbuffer=65536

  feedback=100000volsize=0full=y

  file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)

  log=exp_fulldb_yyyymmdd.log

  对于数据库备份,建议采用增量备份,即只备份上一次备份以来更改的数据。

增量备份命令:

  expicdmain/icdrows=yindexes=ncompress=nbuffer=65536

  feedback=100000volsize=0full=yinctype=incremental

  file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0)

  log=exp_fulldb_yyyymmdd.log

  注:

关于增量备份必须满足下列条件:

  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.

  或

  tar:

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

  若从磁带设备恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=/dev/rmt0

  log=imp_icdmain_csd_yyyymmdd.log

  B.恢复备份数据中的指定表

  若从本地文件恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=exp_icdmain_csd_yyyymmdd.dmp

  log=imp_icdmain_csd_yyyymmdd.log

  tables=commoninformation,serviceinfo

  若从磁带设备恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000ignore=nvolsize=0

  file=/dev/rmt0

  log=imp_icdmain_csd_yyyymmdd.log

  tables=commoninformation,serviceinfo

  用户模式

  此方式将根据按照用户模式备份的数据进行恢复。

  A.恢复备份数据的全部内容

  若从本地文件恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=exp_icdmain_yyyymmdd.dmp

  log=imp_icdmain_yyyymmdd.log

  若从磁带设备恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=/dev/rmt0

  log=imp_icdmain_yyyymmdd.log

  B.恢复备份数据中的指定表

  若从本地文件恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000ignore=nvolsize=0file=exp_icdmain_yyyymmdd.dmp

  log=imp_icdmain_yyyymmdd.log

  tables=commoninformation,serviceinfo

  若从磁带设备恢复,使用如下命令:

  impicdmain/icdfromuser=icdmaintouser=icdmainrows=yindexes=n

  commit=ybuffer=65536feedback=100000igno

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 小学教育 > 语文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1