Oracle Study之--Oracle 11gR2通过RMAN克隆数据库

简介:

Purpose of Database Duplication

A duplicate database is useful for a variety of purposes, most of which involve testing. You can perform the following tasks in a duplicate database:

  • Test backup and recovery procedures

  • Test an upgrade to a new release of Oracle Database

  • Test the effect of applications on database performance

  • Create a standby database

  • Generate reports

Techniques for Duplicating a Database

RMAN supports two basic types of duplication: active database duplication and backup-based duplication. RMAN can perform backup-based duplication with or without either of the following connections:

  • Target

  • Recovery catalog

A connection to both is required for active database duplication.

Figure 24-1 shows the decision tree for the two duplication techniques.



Active Database Duplication

In active database duplication, RMAN connects as TARGET to the source database instance and as AUXILIARY to the auxiliary instance. RMAN copies the live source database over the network to the auxiliary instance, thereby creating the duplicate database. No backups of the source database are required. Figure 24-2 illustrates active database duplication.



     Oracle 11gRMAN duplicate 可以通过Active database duplicateBackup-based duplicate两种方法实现。本案例使用的是Active database duplicate,对于Active database duplicate来说,在克隆数据库时不用对Source备份,这对于大数据特别是T级别的数据库来说优点非常明显,复制前不需要进行备份,减少了备份和传送备份的时间,同时节省备份空间。

    克隆数据库一般是在不同的主机上来完成,本案例是测试环境,所以在一台主机上完成。

1、Source 库信息

[oracle@rh64 ~]$sqlplus '/as sysdba'

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
SQL*Plus: Release  11.2. 0.3. 0  Production  on  Thu Mar  24  16 : 30 : 48  2016
Copyright (c)  1982 2011 , Oracle.  All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release  11.2. 0.3. 0  - 64bit Production
With the Partitioning, OLAP, Data Mining  and  Real Application Testing options
 
16 : 30 : 48  SYS@ prod>select status  from  v$instance;
STATUS
------------
OPEN
 
16 : 31 : 12  SYS@ prod>select name  from  v$datafile;
NAME
------------------------------------------------------------------------------------------------------------------------
/u01/app/oracle/oradata/prod/system01.dbf
/u01/app/oracle/oradata/prod/sysaux01.dbf
/u01/app/oracle/oradata/prod/undotbs01.dbf
/u01/app/oracle/oradata/prod/users01.dbf
/u01/app/oracle/oradata/prod/example01.dbf
/u01/app/oracle/oradata/prod/test1.dbf
6  rows selected.
 
16 : 37 : 41  SYS@ prod>select member  from  v$logfile;
MEMBER
------------------------------------------------------------------------------------------------------------------------
/u01/app/oracle/oradata/prod/redo03.log
/u01/app/oracle/oradata/prod/redo02.log
/u01/app/oracle/oradata/prod/redo01.log
 
16 : 38 : 43  SYS@ prod>show parameter name
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_file_name_convert                 string
db_name                              string      prod
db_unique_name                       string      prod
global_names                         boolean     FALSE
instance_name                        string      prod
lock_name_space                      string
log_file_name_convert                string
processor_group_name                 string
service_names                        string      prod

2、构建测试库:

1)测试库目录环境

[root@rh64 dsk3]# cd test1/
[root@rh64 test1]# ls
oradata  logs admin

2)生成测试库pfile
[oracle@rh64 dbs]$ cat inittest1.ora 
*.audit_file_dest='/dsk3/test1/admin/adump'
*.audit_trail='db'
*.compatible='11.2.0.0.0'
*.control_files='/dsk3/test1/oradata/control01.ctl'
*.db_block_size=8192
*.db_domain=''
*.db_name='test1'
*.diagnostic_dest='/u01/app/oracle'
*.memory_target=319430400
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile='EXCLUSIVE'
*.undo_tablespace='UNDOTBS1'
*.db_file_name_convert=('/u01/app/oracle/oradata/prod/','/dsk3/test1/oradata/')         ;如果源库和目标库在同一台主机,需要配置文件存储路径转换参数
*.log_file_name_convert=('/u01/app/oracle/oradata/prod/','/dsk3/test1/logs/')


3)生成口令文件
[oracle@rh64 dbs]$ cp orapwprod orapwtest1


4)启动Auxiliary Instance到no mount

1
2
3
4
5
6
7
16:52:01 SYS@ test1>startup nomount;
ORACLE instance started.
Total System Global Area  521936896 bytes
Fixed Size                  2229944 bytes
Variable Size             314575176 bytes
Database Buffers          201326592 bytes
Redo Buffers                3805184 bytes

16:52:13 SYS@ test1>show parameter name

1
2
3
4
5
6
7
8
9
10
11
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_file_name_convert                 string   /u01/app/oracle/oradata/p                                                 rod/,/dsk3/test1/oradata/
db_name                             string      test1
db_unique_name                    string      test1
global_names                          boolean      FALSE
instance_name                        string      test1
lock_name_space                   string
log_file_name_convert            string    /u01/app/oracle/oradata/pro                                              d/,/dsk3/test1/logs/
processor_group_name           string
service_names                  string      test1


三、配置网络Listener 和 tnsnames


由于Auxiliary Instance只能启动到no mount状态,所以需要在listener里配置Auxiliary Instance为静态注册,以便RMAN进行连接。

1)配置监听器
[oracle@rh64 admin]$ cat listener.ora 
# listener.ora Network Configuration File: /u01/app/oracle/product/11.2.0/db_1/network/admin/listener.ora
# Generated by Oracle configuration tools.

1
2
3
4
5
6
7
8
LISTENER =
   (DESCRIPTION_LIST =
     (DESCRIPTION =
       (ADDRESS = (PROTOCOL = TCP)(HOST = rh64)(PORT =  1521 ))
       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
     )
   )
ADR_BASE_LISTENER = /u01/app/oracle

# 静态注册Auxiliary Instance:test1
SID_LIST_LISTENER =

  (SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = test1)
      (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_1)
      (SID_NAME = test1)
    )
  )


2)配置tnsnames
[oracle@rh64 admin]$ cat tnsnames.ora 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# tnsnames.ora Network Configuration File: /u01/app/oracle/product/ 11.2 . 0 /db_1/network/admin/tnsnames.ora
# Generated by Oracle configuration tools.
PROD =
   (DESCRIPTION =
     (ADDRESS = (PROTOCOL = TCP)(HOST = rh64)(PORT =  1521 ))
     (CONNECT_DATA =
       (SERVER = DEDICATED)
       (SERVICE_NAME = prod)
     )
   )
TEST1 =
   (DESCRIPTION =
     (ADDRESS = (PROTOCOL = TCP)(HOST = rh64)(PORT =  1521 ))
     (CONNECT_DATA =
       (SERVER = DEDICATED)
       (SERVICE_NAME = test1)
     )
  

3)查看listener信息
 [oracle@rh64 admin]$ lsnrctl status

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
LSNRCTL  for  Linux: Version  11.2. 0.3. 0  - Production  on  24 -MAR -2016  17 : 44 : 04
Copyright (c)  1991 2011 , Oracle.  All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=rh64)(PORT= 1521 )))
STATUS of the LISTENER
------------------------
Alias                     LISTENER
Version                   TNSLSNR  for  Linux: Version  11.2. 0.3. 0  - Production
Start Date                 24 -MAR -2016  17 : 43 : 17
Uptime                     0  days  0  hr.  0  min.  46  sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   /u01/app/oracle/product/ 11.2. 0 /db_1/network/admin/listener.ora
Listener Log File         /u01/app/oracle/diag/tnslsnr/rh64/listener/alert/log.xml
Listening Endpoints Summary...
   (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=rh64.cuug.cn)(PORT= 1521 )))
   (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))
Services Summary...
Service  "prod"  has  1  instance(s).
   Instance  "prod" , status READY, has  1  handler(s)  for  this  service...
Service  "prodXDB"  has  1  instance(s).
   Instance  "prod" , status READY, has  1  handler(s)  for  this  service...
Service  "test1"  has  1  instance(s).
   Instance  "test1" , status UNKNOWN, has  1  handler(s)  for  this  service...   # Auxiliary Instance静态注册后,状态为“UNKNOWN"
The command completed successfully

四、配置RMAN克隆
[oracle@rh64 admin]$ rman target sys/oracle@prod auxiliary sys/oracle@test1
Recovery Manager: Release 11.2.0.3.0 - Production on Thu Mar 24 17:07:38 2016
Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.
connected to target database: PROD (DBID=305104131)
connected to auxiliary database: TEST1 (not mounted)
RMAN> duplicate database to test1 from active database nofilenamecheck;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
   Starting Duplicate Db  at  24 -MAR -16
using target database control file instead of recovery catalog
allocated channel: ORA_AUX_DISK_1
channel ORA_AUX_DISK_1: SID= 20  device type=DISK
contents of Memory Script:
{
    sql clone  "create spfile from memory" ;
}
executing Memory Script
sql statement: create spfile  from  memory
contents of Memory Script:
{
    shutdown clone immediate;
    startup clone nomount;
}
executing Memory Script
Oracle instance shut down
connected to auxiliary database ( not  started)
Oracle instance started
Total System Global Area      321507328  bytes
Fixed Size                      2228024  bytes
Variable Size                 230686920  bytes
Database Buffers               83886080  bytes
Redo Buffers                    4706304  bytes
contents of Memory Script:
{
    sql clone "alter system set  db_name = 
  '' PROD ''  comment=
  '' Modified by RMAN duplicate ''  scope=spfile";
    sql clone "alter system set  db_unique_name = 
  '' TEST1 ''  comment=
  '' Modified by RMAN duplicate ''  scope=spfile";
    shutdown clone immediate;
    startup clone force nomount
    backup  as  copy current controlfile auxiliary format   '/dsk3/test1/oradata/control01.ctl' ;
    alter clone database mount;
}
executing Memory Script
sql statement: alter system set  db_name =   '' PROD ''  comment=  '' Modified by RMAN duplicate ''  scope=spfile
sql statement: alter system set  db_unique_name =   '' TEST1 ''  comment=  '' Modified by RMAN duplicate ''  scope=spfile
Oracle instance shut down
Oracle instance started
Total System Global Area      321507328  bytes
Fixed Size                      2228024  bytes
Variable Size                 230686920  bytes
Database Buffers               83886080  bytes
Redo Buffers                    4706304  bytes
Starting backup  at  24 -MAR -16
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID= 34  device type=DISK
channel ORA_DISK_1: starting datafile copy
copying current control file
output file name=/u01/app/oracle/product/ 11.2. 0 /db_1/dbs/snapcf_prod.f tag=TAG20160324T175437 RECID= 3  STAMP= 907350882
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 00 : 07
Finished backup  at  24 -MAR -16
database mounted
contents of Memory Script:
{
    set newname  for  datafile   1  to 
  "/dsk3/test1/data/system01.dbf" ;
    set newname  for  datafile   2  to 
  "/dsk3/test1/data/sysaux01.dbf" ;
    set newname  for  datafile   3  to 
  "/dsk3/test1/data/undotbs01.dbf" ;
    set newname  for  datafile   4  to 
  "/dsk3/test1/data/users01.dbf" ;
    set newname  for  datafile   5  to 
  "/dsk3/test1/data/example01.dbf" ;
    set newname  for  datafile   6  to 
  "/dsk3/test1/data/test1.dbf" ;
    backup  as  copy reuse
    datafile   1  auxiliary format 
  "/dsk3/test1/data/system01.dbf"    datafile 
  2  auxiliary format 
  "/dsk3/test1/data/sysaux01.dbf"    datafile 
  3  auxiliary format 
  "/dsk3/test1/data/undotbs01.dbf"    datafile 
  4  auxiliary format 
  "/dsk3/test1/data/users01.dbf"    datafile 
  5  auxiliary format 
  "/dsk3/test1/data/example01.dbf"    datafile 
  6  auxiliary format 
  "/dsk3/test1/data/test1.dbf"    ;
    sql  'alter system archive log current' ;
}
executing Memory Script
executing command: SET NEWNAME
executing command: SET NEWNAME
executing command: SET NEWNAME
executing command: SET NEWNAME
executing command: SET NEWNAME
executing command: SET NEWNAME
Starting backup  at  24 -MAR -16
using channel ORA_DISK_1
channel ORA_DISK_1: starting datafile copy
input datafile file number= 00001  name=/u01/app/oracle/oradata/prod/system01.dbf
output file name=/dsk3/test1/oradata/system01.dbf tag=TAG20160324T180122
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 01 : 45
channel ORA_DISK_1: starting datafile copy
input datafile file number= 00002  name=/u01/app/oracle/oradata/prod/sysaux01.dbf
output file name=/dsk3/test1/oradata/sysaux01.dbf tag=TAG20160324T180122
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 01 : 35
channel ORA_DISK_1: starting datafile copy
input datafile file number= 00005  name=/u01/app/oracle/oradata/prod/example01.dbf
output file name=/dsk3/test1/oradata/example01.dbf tag=TAG20160324T180122
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 00 : 55
channel ORA_DISK_1: starting datafile copy
input datafile file number= 00003  name=/u01/app/oracle/oradata/prod/undotbs01.dbf
output file name=/dsk3/test1/oradata/undotbs01.dbf tag=TAG20160324T180122
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 00 : 15
channel ORA_DISK_1: starting datafile copy
input datafile file number= 00006  name=/u01/app/oracle/oradata/prod/test1.dbf
output file name=/dsk3/test1/oradata/test1.dbf tag=TAG20160324T180122
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 00 : 07
channel ORA_DISK_1: starting datafile copy
input datafile file number= 00004  name=/u01/app/oracle/oradata/prod/users01.dbf
output file name=/dsk3/test1/oradata/users01.dbf tag=TAG20160324T180122
channel ORA_DISK_1: datafile copy complete, elapsed time:  00 : 00 : 03
Finished backup  at  24 -MAR -16
sql statement: alter system archive log current
contents of Memory Script:
{
    backup  as  copy reuse
    archivelog like   "/dsk4/arch_prod/arch_1_32_893265808.log"  auxiliary format 
  "/u01/app/oracle/product/11.2.0/db_1/dbs/arch1_32_893265808.dbf"    ;
    catalog clone archivelog   "/u01/app/oracle/product/11.2.0/db_1/dbs/arch1_32_893265808.dbf" ;
    switch clone datafile all;
}
executing Memory Script
Starting backup  at  24 -MAR -16
using channel ORA_DISK_1
channel ORA_DISK_1: starting archived log copy
input archived log thread= 1  sequence= 32  RECID= 26  STAMP= 907351568
output file name=/u01/app/oracle/product/ 11.2. 0 /db_1/dbs/arch1_32_893265808.dbf RECID= 0  STAMP= 0
channel ORA_DISK_1: archived log copy complete, elapsed time:  00 : 00 : 01
Finished backup  at  24 -MAR -16
cataloged archived log
archived log file name=/u01/app/oracle/product/ 11.2. 0 /db_1/dbs/arch1_32_893265808.dbf RECID= 26  STAMP= 907351572
datafile  1  switched to datafile copy
input datafile copy RECID= 4  STAMP= 907351573  file name=/dsk3/test1/oradata/system01.dbf
datafile  2  switched to datafile copy
input datafile copy RECID= 5  STAMP= 907351573  file name=/dsk3/test1/oradata/sysaux01.dbf
datafile  3  switched to datafile copy
input datafile copy RECID= 6  STAMP= 907351574  file name=/dsk3/test1/oradata/undotbs01.dbf
datafile  4  switched to datafile copy
input datafile copy RECID= 7  STAMP= 907351574  file name=/dsk3/test1/oradata/users01.dbf
datafile  5  switched to datafile copy
input datafile copy RECID= 8  STAMP= 907351574  file name=/dsk3/test1/oradata/example01.dbf
datafile  6  switched to datafile copy
input datafile copy RECID= 9  STAMP= 907351574  file name=/dsk3/test1/oradata/test1.dbf
contents of Memory Script:
{
    set until scn   1471172 ;
    recover
    clone database
     delete  archivelog
    ;
}
executing Memory Script
executing command: SET until clause
Starting recover  at  24 -MAR -16
allocated channel: ORA_AUX_DISK_1
channel ORA_AUX_DISK_1: SID= 18  device type=DISK
starting media recovery
archived log  for  thread  1  with  sequence  32  is already  on  disk  as  file /u01/app/oracle/product/ 11.2. 0 /db_1/dbs/arch1_32_893265808.dbf
archived log file name=/u01/app/oracle/product/ 11.2. 0 /db_1/dbs/arch1_32_893265808.dbf thread= 1  sequence= 32
media recovery complete, elapsed time:  00 : 00 : 05
Finished recover  at  24 -MAR -16
Oracle instance started
Total System Global Area      321507328  bytes
Fixed Size                      2228024  bytes
Variable Size                 234881224  bytes
Database Buffers               79691776  bytes
Redo Buffers                    4706304  bytes
contents of Memory Script:
{
    sql clone "alter system set  db_name = 
  '' TEST1 ''  comment=
  '' Reset to original value by RMAN ''  scope=spfile";
    sql clone  "alter system reset  db_unique_name scope=spfile" ;
    shutdown clone immediate;
    startup clone nomount;
}
executing Memory Script
sql statement: alter system set  db_name =   '' TEST1 ''  comment=  '' Reset to original value by RMAN ''  scope=spfile
sql statement: alter system reset  db_unique_name scope=spfile
Oracle instance shut down
connected to auxiliary database ( not  started)
Oracle instance started
Total System Global Area      321507328  bytes
Fixed Size                      2228024  bytes
Variable Size                 234881224  bytes
Database Buffers               79691776  bytes
Redo Buffers                    4706304  bytes
sql statement: CREATE CONTROLFILE REUSE SET DATABASE  "TEST1"  RESETLOGS ARCHIVELOG 
   MAXLOGFILES      16
   MAXLOGMEMBERS       3
   MAXDATAFILES       100
   MAXINSTANCES      8
   MAXLOGHISTORY       292
  LOGFILE
   GROUP    1  '/dsk3/test1/logs/' 'redo01.log'  ) SIZE  50  M  REUSE,
   GROUP    2  '/dsk3/test1/logs/' 'redo02.log'  ) SIZE  50  M  REUSE,
   GROUP    3  '/dsk3/test1/logs/' 'redo03.log'  ) SIZE  50  M  REUSE
  DATAFILE
   '/dsk3/test1/oradata/system01.dbf'
  CHARACTER SET ZHS16GBK
contents of Memory Script:
{
    set newname  for  tempfile   1  to 
  "/dsk3/test1/oradata/temp01.dbf" ;
    switch clone tempfile all;
    catalog clone datafilecopy   "/dsk3/test1/oradata/sysaux01.dbf"
  "/dsk3/test1/oradata/undotbs01.dbf"
  "/dsk3/test1/oradata/users01.dbf"
  "/dsk3/test1/oradata/example01.dbf"
  "/dsk3/test1/oradata/test1.dbf" ;
    switch clone datafile all;
}
executing Memory Script
executing command: SET NEWNAME
renamed tempfile  1  to /dsk3/test1/oradata/temp01.dbf  in  control file
cataloged datafile copy
datafile copy file name=/dsk3/test1/oradata/sysaux01.dbf RECID= 1  STAMP= 907351727
cataloged datafile copy
datafile copy file name=/dsk3/test1/oradata/undotbs01.dbf RECID= 2  STAMP= 907351728
cataloged datafile copy
datafile copy file name=/dsk3/test1/oradata/users01.dbf RECID= 3  STAMP= 907351728
cataloged datafile copy
datafile copy file name=/dsk3/test1/oradata/example01.dbf RECID= 4  STAMP= 907351728
cataloged datafile copy
datafile copy file name=/dsk3/test1/oradata/test1.dbf RECID= 5  STAMP= 907351729
datafile  2  switched to datafile copy
input datafile copy RECID= 1  STAMP= 907351727  file name=/dsk3/test1/oradata/sysaux01.dbf
datafile  3  switched to datafile copy
input datafile copy RECID= 2  STAMP= 907351728  file name=/dsk3/test1/oradata/undotbs01.dbf
datafile  4  switched to datafile copy
input datafile copy RECID= 3  STAMP= 907351728  file name=/dsk3/test1/oradata/users01.dbf
datafile  5  switched to datafile copy
input datafile copy RECID= 4  STAMP= 907351728  file name=/dsk3/test1/oradata/example01.dbf
datafile  6  switched to datafile copy
input datafile copy RECID= 5  STAMP= 907351729  file name=/dsk3/test1/oradata/test1.dbf
Reenabling controlfile options  for  auxiliary database
Executing: alter database enable block change tracking using file  '/dsk4/backup/block.trc'
ORACLE error  from  auxiliary database: ORA -19751 : could  not  create the change tracking file
ORA -19750 : change tracking file:  '/dsk4/backup/block.trc'
ORA -27038 : created file already exists
Additional information:  1
Ignoring error, reattempt command  after  duplicate finishes
contents of Memory Script:
{
    Alter clone database open resetlogs;
}
executing Memory Script
database opened
Finished Duplicate Db  at  24 -MAR -16

五、验证克隆

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
Connected to:
Oracle Database 11g Enterprise Edition Release  11.2. 0.3. 0  - 64bit Production
With the Partitioning, OLAP, Data Mining  and  Real Application Testing options
18 : 28 : 57  SYS@ test1>select status  from  v$instance;
STATUS
------------
OPEN
 
18 : 29 : 06  SYS@ test1>select name  from  v$datafile;
NAME
--------------------------------------------------------------------------
/dsk3/test1/oradata/system01.dbf
/dsk3/test1/oradata/sysaux01.dbf
/dsk3/test1/oradata/undotbs01.dbf
/dsk3/test1/oradata/users01.dbf
/dsk3/test1/oradata/example01.dbf
/dsk3/test1/oradata/test1.dbf
6  rows selected.
 
18 : 29 : 13  SYS@ test1>select member  from  v$logfile;
MEMBER
--------------------------------------------------------------------------
/dsk3/test1/logs/redo03.log
/dsk3/test1/logs/redo02.log
/dsk3/test1/logs/redo01.log
 
18 : 30 : 19  SYS@ test1>show parameter control
NAME                                 TYPE        VALUE
------------------------------------ ----------- -------------------------
control_files                        string      /dsk3/test1/oradata/control01.ctl

   


-------- 至此,数据库克隆成功 !                                     











本文转自 客居天涯 51CTO博客,原文链接:http://blog.51cto.com/tiany/1755114,如需转载请自行联系原作者
目录
相关文章
|
16天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
63 11
|
29天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
1月前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
22天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
1月前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
54 7
|
1月前
|
Oracle 关系型数据库 数据库
oracle数据库技巧
【10月更文挑战第25天】oracle数据库技巧
32 6
|
1月前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
31 5
|
4天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
13 3
|
4天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
20 3
|
4天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
25 2

推荐镜像

更多