一、意义:
当我们使用一个数据库时,总希望数据库的内容是可靠的、正确的,但由于计算机系统的故障(硬件故障、网络故障、进程
故障和系统故障)影响数据库系统的操作,影响数据库中数据的正确性,甚至破坏数据库,使数据库中全部或部分数据丢
失。因此当发生上述故障后,希望能重新建立一个完整的数据库,该处理称为数据库恢复。恢复子系统是数据库管理系统
的一个重要组成部分。恢复处理随所发生的故障类型所影响的结构而变化。
二、备份的方法
ORACLE数据库有三种标准的备份。导出/导入(EXPORT/IMPORT) 、冷备份、热备份。
导出备份是一种逻辑备份,这种方法包括读取一系列的数据库日志,并写入文件中,这些日志的读取与其所处位置无关。
冷备份和热备份是物理备份(也称低级备份),它涉及到组成数据库的文件,但不考虑逻辑内容。
下面我们分别介绍一下这三种备份方法及其特点:
(一)、导出/导入(EXPORT/IMPORT)
EXPORT/IMPORT是用来将ORACLE中数据移出/移入数据库。
1、EXPORT将数据库中数据备份成一个二进制系统文件称为“导出转储文件”(EXPORT DUMP FILE),并将重新生成数据库写
入文件中。
它有三种模式:
a.用户模式:导出用户所有对象以及对象中的数据;
b.表模式:导出用户所有表或者指定的表;
c.整个数据库:导出数据库中所有对象。
它的备份有三种类型:
a.完全型(COMPLETE EXPORT):备份整个数据库;
b.积累型(COMULATIVE ERPORT):备份上一次积累型备份所改变的数据;
c.增量型(INCREAMENTAL EXPORT):备份上一次备份后改变的数据。
EXPORT 的命令可以交互式进行,各参数的具体含义见附录。
在进行导出备份时我们要考虑一点问题,那就是导出的一致性,在导出过程 中导出每读一次就读取一个表,因而尽管导出
是在一个特点时自己开始的,但不同的表读取的时间不同,因此,导出开始读一个表时,此时表中的数据才是导出的数
据,这样当大多数表按内部关键字和外部关键字相互联系时,在导出过程中这些相关联表的改变就会导致导出的不一致
性,要避开这个,我们可以将导出过程安排在不对表操作的时候进行。另外,当ORACLE中RESTRICTEP CONSISTENT 选项就
可以保证导出数据一致性。
2、IMPORT导入:
导入的过程是导出的逆过程,这个命令先读取导出来的导出转储二进制文件,并运行文件,恢复对象用户和数据。
IMPORT命令执行的方法和EXPORT方案有关。
1、如果EXPORT所实施的是完全型方案(FULL)则在IMPORT时所有的数据对象,包括表空间,数据文件,用户都会在导入时创
建,但考虑到数据库中的物理布局,预先创建表空间和用户是有用的。
2、如果EXPORT使用的是INCREMENTAL/CUMULATIVE方式,则需要预先设置好表空间、用户、数据文件。
(二):冷备份
冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库。
数据库使用的每个文件都被备份下来,这些文件包括:
☆所有数据文件
☆所有控制文件
☆所有联机REDO LOG 文件
☆INIT.ORA文件(可选)
值得注意的是冷备份必须是数据库关闭的情况下完成,当数据库开着的时候,执行数据库文件系统备份无效。
作冷备份一般步骤是:
1:正常关闭要备份的实例(instance);
2: 备份整个数据库到一个目录
3:启动数据库
1: SQLDBA>connect internal
SQLDBA>shutdown normal
2: SQLDBA>! cp
1<file> <backup directory="">
2或
3SQLDBA>!tar cvf /dev/rmt/0 /wwwdg/oracle
43: SQLDBA>startup
5
6(三)热备份(ACHIRELOG)
7数据库需要二十四小时运行,而且随时有新的数据加入.数据丢失将影响整个公司.采用archivelog mode物理备份.
8?设置数据库为automatic archivelog mode,
9#su - oracle
10%svrmgrl
11svrmgrl>connect internal
12svrmgrl>startup mount
13svrmgrl>alter database archivelog
14svrmgrl>shutdown
15svrmgrl>exit
16%vi initoracle7.ora
17加入log_archive_start = true # if you want automatic archiving
18log_archive_dest = $ORACLE_HOME/dbs/arch
19log_archive_format = log%s.arc
20%dbstart
21%ps -ef|grep arch
22oracle 1743 1 0 15:20:20 ? 0:00 ora_arch_oracle7
23注:oracle database is in automatic archivelog mode
24
25?full offline entire database backup, 当数据库初始完成后 这份备份是将来备份的基础。它提供了所有与数据库有关
26的拷贝.
27%dbshut
28%cp /oracle/oradata/oracle7/system.dbf
29/oracle/oradata/oracle7/rbs.dbf
30/oracle/oradata/oracle7/temp.dbf
31/oracle/oradata/oracle7/tools.dbf
32/oracle/oradata/oracle7/users.dbf
33/oraclecle/app/oracle/product/7.3.2/dbs/application.dbf
34/oracle/app/oracle/product/7.3.2/dbs/apptmpsp.dbf
35/oracle/app/oracle/product/7.3.2/dbs/apprlbksp.dbf
36/oracle/oradata/oracle7/redooracle.log
37/oracle/oradata/oracle7/control1.ctl
38/oracle/oradata/oracle7/control2.ctl
39/oracle/oradata/oracle7/control3.ctl
40<backup directory="">
41%dbstart
42注:以上*.dbf文件为数据文件,*.log文件为日志文件,*.ctl文件为控制文件
43%exit
44%tar uvf /dev/rmt/0 <backup files="">
45注:如果为oracle 7.2 ,则copy 相应的 data files,relog files,control files.
46
476.3、每天做一次 partial online with archiving backups .
48#su - oracle
49%svrmgrl
50%svrmgrl>connect internal
51%svrmgrl>alter tablespace billsp begin backup
52%svrmgrl>alter tablespace billtmpsp begin backup
53%svrmgrl>alter tablespace billrlbksp begin backup
54%svrmgrl>alter tablespace system begin backup
55%svrmgrl>alter tablespace rbs begin backup
56%svrmgrl>alter tablespace temp begin backup
57%svrmgrl>alter tablespace tools begin backup
58%svrmgrl>alter tablespace users begin backup
59%svrmgrl>host cp all datafile to the backup storage. #文件名如第一步中以.dbf结尾的.
60%svrmgrl>alter tablespace billsp end backup
61%svrmgrl>alter tablespace billtmpsp end backup
62%svrmgrl>alter tablespace billrlbksp end backup
63%svrmgrl>alter tablespace system end backup
64%svrmgrl>alter tablespace rbs end backup
65%svrmgrl>alter tablespace temp end backup
66%svrmgrl>alter tablespace tools end backup
67%svrmgrl>alter tablespace users end backup
68
69做一个sql文件,如上所写.
70
71The billing system can recover to the point of failure when the failure occur.
72
73七、备份文件的恢复:
747.1恢复文件:
75以下是对"/etc/passwd"文件的恢复
76(、放入正确的磁带
77(、运行以下命令恢复"/etc/passwd"文件
78# rsh www mt -f /dev/rmt/0 rew
79( 找到最近的磁带,向前进带到最近的"/etc/passwd",比如要找星期三的"/etc/passwd"文件,运行如下命令)
80#rsh www mt -f /dev/rmt/0n fsf 2
81# ufsrestore if www:/dev/rmt/0n
82ufsrestore > ls
83.:
84etc/
85ufsrestore > cd etc
86ufsrestore > ls
87./etc:
88passwd
89ufsrestore > add passwd
90Warnign :./etc:File exists
91ufsrestore > verbose
92verbose mode on
93ufsrestore > extract
94Extract requested files
95You have not read any volumes yet .
96Unless you know which volume your file(s) are on you should start witch the last volume and work to wards
97the first.
98Specify next volume #:1
99extract file ./etc/passwd
100Add links
101Set directory mode ,ower,and times.
102set owner /mode for '.'?(yn)n
103Directories already exit , set mode anyway?(yn)y
104ufsrestore >quit
105热备份可以在数据库打开打情况下进行,一般通过使用Alter命令改变表空间的状态来开始进行备份的,备份完成后,
106要恢其原来状态,否则redo log 会错配,引起数据库下次启动时对受影响的表空间进行完全覆盖。热备份的要求是:
1071.热备份工作必需要求数据库在Archivelog 方式下操作,在SQLDBA状态下用alter database archivelog|noarchivelog命
108令可改变备份的模式。
1092.热备份只能在数据库不使用或使用率低的情况下进行。
1103.热备份需要大量的档案空间。
111一般情况,Oracle 以循环的方式写入Online redo log 文件,当填满第一个redo log文件后写第二个,直至最后一个,最
112后一个被填满后,后台进程LGWR就覆盖第一个,在Archivelog方式下,后台进程ARCH在每一个redo log 文件被覆盖前,给
113它作一个拷贝,一般,这些文档的redo log 文件被写入磁盘或磁带中。如果磁盘空间够用,建议使用磁盘,这样可大大减
114少完成备份所需的时间。
115在作热备份之前,要将config.ora文件中的log_archive_start 设为true 将log_archive_dest
116规定archive redo log 文件的位置:
117log_archive_dest=/wwwdg/oracle/arch/arch
118log_archive_start=true
119一旦数据库运行在archivelog状态下,就可以作备份了。热备份的命令文件由三部分组成:
1201、数据文件一个表空间一个空间地备份:
121a.设置表空间为备份状态。
122b.备份表空间的数据文件。
123c.恢复表空间为正常状态。
1242、备份归档要作log 文件:
125a.临时停止归档进程
126b.log下那些在archive redo log目标目录中的文件
127c.重新启动archive进程
128d.备份归档的redo log 文件
1293、用alter database backup controlfile命令来备份拷贝文件
130在热备份运行之前log_archive_dest目录可能已满,这时就要备份目录,然后删除文件,释放空间,这个过程有如下步
131骤:
1321、暂时停止archive进程。
1332、记录在log_archive_dest目录下的文件。
1343、重新启动archive 进程。
1354、备份archive redo log 文件。
1365、删除目录中的文件。
137sqldba lmode=y <<eof -f="" -rvf="" 0="" ;="" ?%svrmgrl="" ?svrmgrl="" ?将最近copyes="" arch1="" arch2="" archive="" connect="" datafile,拷贝到$oracle_home="" dbs目录。="" dev="" eof="" exit="" export导出="" files="" internal="" lmode="y<<EOF" log="" of="" rm="" rmt="" sqldba="" start;="" stop;="" tar="" 乻hutdown="" 前面介绍了三种备份的方法,在数据库做备份时,应该将数据这三种备份的特点灵活运用,我们首先比较一下三种方法的="" 可以将任何数据库对象恢复到它被导出时的状态="" 型="" 复="" 性="" 恢="" 方="" 法="" 特="" 特性。="" 类="" 逻辑型="" 逻辑备份与物理备份的结合。="" $files="">connect internal
138…svrmgrl>startup mount pfile=filename exclusive
139?svrmgrl>alter database recover;
140注:将自动恢复数据到the point of failure;
141? svrmgrl>alter database open;
142?当archive log文件过多时,在 做过部分备份后,可将current log sequence 之前的log***.arc删除.
143#su - oracle
144%svrmgrl
145svrmgrl>connect internal;
146svrmgrl>archive log list;
147#此处标有current log sequence.假设为360。
148Svrmgrl>exit
149$cd /billdg/oracle/app/oracle/product/7.3.2/dbs/arch
150$ rm ......... #将log360.arc之前的文件如log359.arc,log358.arc.............删除。
151冷 备 份
152物理型
153可将数据库到它被关闭的状态
154热 备 份
155物理型
156可将数据库恢复到任一时间点的状态
157
158当数据库比较小时,处理业务也小时,冷备份导出就可以了。如果只对一两个表备份导出就够了。一般来说一个好,备份最
159终执行总包括逻辑和物理,导出确认数据库在逻辑的正确性而物理备份确保物理。
160另外,在进行备份时需要一些存储介质,对于这些介质应该对其作好管理
1611:根据备份的内容,日期将介质统一编号,以免备份和恢复时弄错介质,造成原有的备份丢失。
1622:介质应存放在与计算机设备不同的地点,以免机房发生意外时,备份与计算机设备一同损坏。
163
164附录:
165tar命令
166tar option [arguments] filename...
167option:
168c:创建一个由命令行指定的新的tarfile
169t:列出tarfile中的内容
170x:打开tarfile;
171f:使用其后的filename 或/dev/rmt/0|1
172v:列出被恢复的文件名;
173p:恢复文件
174example:
175#tar cvf /dev/rmt/0 /oracle
176备份/root 下的所有内容
177#tar tvf /dev/rmt/0
178列出磁带上的所有内容
179#tar xvf /dev/rmt/0 /oracle
180将磁带上的/oracle目录中的内容恢复到当前目录中
181
182导出选项
183关键字 内 容
184USERID 运行导出命令的帐号的用户名/口令。
185BUFFEER 用来取数据行的缓冲区的大小。
186FILE 导出转储文件的名字
187COMPRESS 导出是否应该压缩有碎片的段成一个范围,这将会影响STORAGE
188子句,
189GRANTS 导出时否要导出数据库对象上的授权
190INDEXES 是否要导出表上的索引
191ROWS 是否应导出行。如它为‘N’,那么在导出文件中仅生成数据库
192对象的DDL
193CONSSTRAINTS 是否导出表旧的约定条件
194FULL 如设为‘Y’,那么将执行一个整个数据库导出操作
195OWNER 要导出的一系列数据库帐号,然后执行这些帐号的USER导出操
196作
197TABLES 要导出的一系列表;执行这些表的TABLE导出操作
198RECORDLENGTH 转储导出文件日志的长度(以字节为单位),通常都使用缺省,除
199非要在两个不同操作系统中传递导出文件
200INCTYPE 正在执行的导出操作的类型(有效值有”COMPLETE“(缺省值),
201CUMULATIVE”和“IVCREMENTAL”)
202RECORD 在增量导出类型中的一个标记,标明是否将日志存储到数据字典
203中日志导出的表中
204PARFILE 要传递给导出的参数文件的名字。这个文件将包含所有参数的入
205口项
206ANALYZE 标明是否将移对象的统计信息写入导出转储文件中
207CONSISTENT 标明是否保留所有导出对象的读取一致复制。
208LOG 导出日志将要写入的文件的名字
209MLS 标明是否要导出MLS 标号
210MLS_LABEL_ 规定了MLS标号的格式
211
212导入选择项
213USERID 运行导入命令的帐号的用户名/口令。
214BUFFEER 用来取数据行的缓冲区的大小。
215FILE 导入转储文件的名字
216SHOW 规定文件内容是否被显示,而不是被执行。
217EGORE 标明在执行‘CREATE’命令时,是否忽略遇到的错误。如果正
218在导入的对象已经存在时,应使用这个参数。
219FULL 如设为‘Y’,那么将执行一个整个数据库导入操作
220FROMUSER 在FULL=N的情况下,才有参数。它是一系列的数据库帐号,其
221对象应从导出转储文件中读取。
222TOUSER 一系列数据库帐号,导出转储文件扣的对象将要导入这些帐号。
223GRANTS 导入时否要导入数据库对象上的授权
224INDEXES 是否要导入表上的索引
225ROWS 是否应导入行。如它为‘N’,那么在导入文件中执行数据库对
226象的DDL
227FULL 如设为‘Y’,那么将执行一个整个数据库导出操作
228TABLES 要导入的一系列表
229RECORDLENGTH 转储导入文件日志的长度(以字节为单位),通常都使用缺省,除
230非要在两个不同操作系统中传递导入文件
231INCTYPE 正在执行的导入操作的类型(有效值有”COMPLETE“(缺省值),
232CUMULATIVE”和“IVCREMENTAL”)
233PARFILE 要传递给导入的参数文件的名字。这个文件将包含所有参数的入
234口项
235ANALYZE 标明是否将移对象的统计信息写入导入转储文件中
236LOG 导入日志将要写入的文件的名字
237MLS 标明是否要导入MLS 标号
238
239热备份的命令文件:
240ORACLE_SID=oracle7
241ORACLE_HOME=/wwwdg/oracle
242sqldba lmode=y<<EOF arch1
243connect internal
244alter tablespace SYSTEM begin backup;
245!tar -cvf /dev/rmt/0 /wwwdg/oracle/dbms/sys01.dbf
246alter tablespace SYSTEM end backup;
247
248alter tablespace BWT begin backup;
249!tar -cvf /dev/rmt/0 /wwwdg/oracle/dbms/BWT1.dbf
250alter tablespace BWT end backup;
251
252archive log stop
253exit
254EOF arch1
255FILES='ls /wwwdg/oracle/arch/arch*.dbf';
256
257sqldba lmode=y<<EOF arch2
258connect internal
259archive log start;
260exit
261EOF arch2
262
263tar -rvf /dev/rmt/0 $FILES
264rm -f $files
265
266sqldba lmode=y<<EOFarch3
267alter database backup controlfile to
268'/wwwdg/oracle/dbms/bwtcontrfile.backup';
269exit
270EOF arch3
271
272tar -rvf /dev/rmt/0 /wwwdg/oracle/bwt/bwtcontrofile.backup</eof></backup></backup></backup></file>