Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1126068
  • 博文数量: 276
  • 博客积分: 10077
  • 博客等级: 上将
  • 技术积分: 2513
  • 用 户 组: 普通用户
  • 注册时间: 2007-08-24 20:31
文章分类

全部博文(276)

文章存档

2020年(1)

2015年(5)

2012年(2)

2011年(6)

2010年(7)

2009年(224)

2008年(31)

我的朋友

分类: Oracle

2009-07-11 22:59:37

数据库从裸设备迁移到文件系统
 
操作系统:RHEL 2.6.9-78.ELsmp 32bit
数据库版本:10.2.0.1 32bit
文件系统:裸设备 -> 文件系统
一、查看裸设备各个数据文件所在的位置
SQL> select tablespace_name,file_name,bytes/1048576 from dba_data_files;
 
TABLESPACE_NAME      FILE_NAME            BYTES/1048576
-------------------- -------------------- -------------
USERS                /dev/raw/raw10                   5
SYSAUX               /dev/raw/raw3                  230
UNDOTBS1             /dev/raw/raw2                   25
SYSTEM               /dev/raw/raw1                  480
 
SQL> select group#,member from v$logfile;
 
    GROUP# MEMBER
---------- ------------------------------
         2 /dev/raw/raw9
         1 /dev/raw/raw8
 
SQL> select name from v$controlfile;
 
NAME
--------------------------------------------------------------------------------
/dev/raw/raw6
/dev/raw/raw7
 
二、备份数据库到文件系统
RMAN> run{
2> allocate channel ch0 type disk format='/mnt1/data/%U';
3> backup database ;
4> sql 'alter system switch logfile';
5> release channel ch0;
6> }
三、修改初始化参数中控制文件的位置
*.control_files='/mnt1/data/CONTROL01.CTL','/mnt1/data/CONTROL02.CTL'
四、从备份集还原数据库到文件系统
1)启动数据库到nomunt
SQL> conn / as sysdba
Connected to an idle instance.
SQL> startup nomount
ORACLE instance started.
 
Total System Global Area  281018368 bytes
Fixed Size                  1218968 bytes
Variable Size              88082024 bytes
Database Buffers          188743680 bytes
Redo Buffers                2973696 bytes
SQL> exit
Disconnected from Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
[oracle@localhost ~]$ rman
 
Recovery Manager: Release 10.2.0.1.0 - Production on Sat Jul 11 20:05:14 2009
 
Copyright (c) 1982, 2005, Oracle.  All rights reserved.
 
RMAN> connect target
 
connected to target database: LGX (not mounted)
2)还原控制文件
RMAN> restore controlfile from '/mnt1/data/08kjt1f2_1_1';
 
Starting restore at 11-JUL-09
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=156 devtype=DISK
 
channel ORA_DISK_1: restoring control file
channel ORA_DISK_1: restore complete, elapsed time: 00:00:02
output filename=/mnt1/data/CONTROL01.CTL
output filename=/mnt1/data/CONTROL02.CTL
Finished restore at 11-JUL-09
RMAN> sql 'alter database mount';
 
sql statement: alter database mount
released channel: ORA_DISK_1
 
3)修改日志文件的路径
SQL>alter database rename file '/dev/raw/raw8' to '/mnt1/data/redo1_1.ora';
Database altered.
SQL>alter database rename file '/dev/raw/raw9' to '/mnt1/data/redo2_1.ora';
Database altered.
是为了在open resetlogs后日志文件也是在文件系统中。
3)还原数据库
run{
allocate channel ch0 type disk;
set newname for datafile '/dev/raw/raw10' to '/mnt1/data/users01.dbf';
set newname for datafile '/dev/raw/raw3' to '/mnt1/data/sysaux01.dbf';
set newname for datafile '/dev/raw/raw2' to '/mnt1/data/undotbs01.dbf';
set newname for datafile '/dev/raw/raw1' to '/mnt1/data/system01.dbf';
restore database;
switch datafile all;
recover database;
alter database open resetlogs;
release channel ch0;
}

4)添加临时表空间
SQL> alter tablespace temp add tempfile '/mnt1/data/temp01.dbf' size 10M;

5)查看数据库文件位置
SQL> select tablespace_name,file_name,bytes/1048576 from dba_data_files;
 
TABLESPACE_NAME      FILE_NAME                      BYTES/1048576
-------------------- ------------------------------ -------------
USERS                /mnt1/data/users01.dbf                     5
SYSAUX               /mnt1/data/sysaux01.dbf                  230
UNDOTBS1             /mnt1/data/undotbs01.dbf                  25
SYSTEM               /mnt1/data/system01.dbf                  480
SQL> select group#,member from v$logfile;
 
    GROUP# MEMBER
---------- ------------------------------
         2 /mnt1/data/redo2_1.ora
         1 /mnt1/data/redo1_1.ora
SQL> select name from v$controlfile;
 
NAME
--------------------------------------------------------------------------------
/mnt1/data/CONTROL01.CTL
/mnt1/data/CONTROL02.CTL
阅读(1575) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~