小編給大家分享一下如何修改ASM磁盤(pán)冗余度,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的永平網(wǎng)站建設(shè)公司,永平接單;提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行永平網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
翻了一下官方文檔:
Automatic Storage Management Administrator's Guide -〉
4 Administering Oracle ASM Disk Groups -〉
Using the CREATE DISKGROUP SQL Statement -〉 Specify the redundancy level of the disk group.
After a disk group is created, you cannot alter the redundancy level of the disk group. To change the redundancy level, you must create another disk group with the appropriate redundancy and then move the files to the new disk group.
一個(gè)ASM磁盤(pán)組創(chuàng)建后,不能修改該磁盤(pán)組的冗余級(jí)別。如果想要修改磁盤(pán)組的冗余級(jí)別,你必須創(chuàng)建另一個(gè)適當(dāng)冗余級(jí)別的磁盤(pán)組,然后把數(shù)據(jù)移動(dòng)到新的磁盤(pán)組。
官方文檔鏈接:http://docs.oracle.com/cd/E11882_01/server.112/e18951/asmdiskgrps.htm#CHDBDAGI
###############################################################
于是有了下面的實(shí)驗(yàn):
由于之前的虛擬機(jī)環(huán)境為10gASM(下次用11g測(cè)下,步驟應(yīng)當(dāng)差不多),并且數(shù)據(jù)庫(kù)存放在+DATA磁盤(pán)上,+DATA磁盤(pán)設(shè)定的冗余度為常規(guī)冗余,故本實(shí)驗(yàn)將由常規(guī)冗余改為外部冗余。
外部冗余改為常規(guī)冗余和該實(shí)驗(yàn)步驟基本一致。
###############################################################
遷移步驟:
先創(chuàng)建一個(gè)新ASM磁盤(pán)組。
先將控制文件遷移至磁盤(pán)組,再遷移數(shù)據(jù)文件、日志文件等。
###############################################################
一、創(chuàng)建一個(gè)新的磁盤(pán)組
10g用dbca,11g用asmca,或者直接用指令也可以,這里我用dbca:
查看一下磁盤(pán)組:
點(diǎn)擊(此處)折疊或打開(kāi)
[root@oracle4 ~]# su - oracle
[oracle@oracle4 ~]$ export ORACLE_SID=+ASM
[oracle@oracle4 ~]$ sqlplus / as sysdba
SQL*Plus: Release 10.2.0.1.0 - Production on Wed Aug 19 01:17:26 2015
Copyright (c) 1982, 2005, Oracle. All rights reserved.
Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
SQL> select state,name,type from v$asm_diskgroup;
STATE NAME TYPE
----------- ------------------------------ ------
MOUNTED DATA NORMAL
MOUNTED RECOVER EXTERN
MOUNTED NEWDG EXTERN
----這里,我們創(chuàng)建了一個(gè)新的ASM磁盤(pán)組,名為NEWDG,外部冗余。
環(huán)境:舊控制文件放在+data磁盤(pán)組上,新的放在+newdg磁盤(pán)組上
遷移方法:先在+newdg上增加一個(gè)控制文件,再刪除+data磁盤(pán)上舊的控制文件
遷移步驟:如下:
----1.將參數(shù)文件中,控制文件的參數(shù)由+DATA磁盤(pán)上的一個(gè)路徑改為兩個(gè)路徑,
SQL> alter system set control_files='+DATA/asmdb/controlfile/current.260.886430449','+newdg' scope=spfile;
----2. 改為兩個(gè)路徑以后,由于第二個(gè)文件并不存在,會(huì)報(bào)錯(cuò)。
----這時(shí)重啟數(shù)據(jù)庫(kù)至nomount模式,使用rman從第一個(gè)控制文件恢復(fù)第二個(gè)控制文件
SQL> startup force nomount;
ORACLE instance started.
Total System Global Area 608174080 bytes
Fixed Size 1220844 bytes
Variable Size 180358932 bytes
Database Buffers 423624704 bytes
Redo Buffers 2969600 bytes
[oracle@oracle4 dbs]$ rman target /
Recovery Manager: Release 10.2.0.1.0 - Production on Wed Aug 19 01:47:18 2015
Copyright (c) 1982, 2005, Oracle. All rights reserved.
connected to target database: asmdb (not mounted)
RMAN> restore controlfile from '+DATA/asmdb/controlfile/current.260.886430449';
Starting restore at 19-AUG-15
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: copied control file copy
output filename=+DATA/asmdb/controlfile/current.260.886430449
output filename=+NEWDG/asmdb/controlfile/backup.257.888112073
Finished restore at 19-AUG-15
---紅色標(biāo)注的是生成的新的控制文件
---這時(shí)啟動(dòng)數(shù)據(jù)庫(kù)至nomount模式
---你會(huì)發(fā)現(xiàn)參數(shù)被修改了:
RMAN> alter database mount;
database mounted
released channel: ORA_DISK_1
[oracle@oracle4 dbs]$ sqlplus / as sysdba
SQL*Plus: Release 10.2.0.1.0 - Production on Wed Aug 19 01:48:48 2015
Copyright (c) 1982, 2005, Oracle. All rights reserved.
Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
SQL> show parameter control
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
control_file_record_keep_time integer 7
control_files string +DATA/asmdb/controlfile/curren
t.260.886430449, +NEWDG/asmdb/controlfile/backup.257.888112073
新控制文件參數(shù)變成了前面rman恢復(fù)的控制文件的位置,如下:
+DATA/asmdb/controlfile/current.260.886430449 ---這是舊的
+NEWDG/asmdb/controlfile/backup.257.888112073 ---這是新的,我們需要被遷移到的位置,我們發(fā)現(xiàn)控制文件已經(jīng)被遷移到了新的位置,接下來(lái)需要?jiǎng)h除舊的控制文件
----3.刪除舊的控制文件,因此將其從控制文件參數(shù)中剔除:
SQL> alter system set control_files='+NEWDG/asmdb/controlfile/backup.257.888112073' scope=spfile;
System altered.
SQL> startup force ;
ORACLE instance started.
Total System Global Area 608174080 bytes
Fixed Size 1220844 bytes
Variable Size 180358932 bytes
Database Buffers 423624704 bytes
Redo Buffers 2969600 bytes
Database mounted.
Database opened.
SQL> show parameter control
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
control_file_record_keep_time integer 7
control_files string +NEWDG/asmdb/controlfile/backup.257.888112073
至此,控制文件被成功移動(dòng)到+NEWDG磁盤(pán)上。
三、將數(shù)據(jù)文件遷移到新的磁盤(pán)組
環(huán)境:舊數(shù)據(jù)文件放在+data磁盤(pán)組上,新的放在+newdg磁盤(pán)組上
遷移方法:先在+newdg上做數(shù)據(jù)文件的鏡像拷貝,再做switch告訴控制文件我們的數(shù)據(jù)文件在+newdg上,而非+data磁盤(pán)上
遷移步驟:如下:
----1.拷貝數(shù)據(jù)文件
[oracle@oracle4 dbs]$ rman target /
Recovery Manager: Release 10.2.0.1.0 - Production on Wed Aug 19 01:51:13 2015
Copyright (c) 1982, 2005, Oracle. All rights reserved.
connected to target database: ASMDB (DBID=630629232)
RMAN> backup as copy database format '+newdg';
Starting backup at 19-AUG-15
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=144 devtype=DISK
channel ORA_DISK_1: starting datafile copy
input datafile fno=00001 name=+DATA/asmdb/datafile/system.256.886430341
output filename=+NEWDG/asmdb/datafile/system.258.888112285 tag=TAG20150819T015122 recid=6 stamp=888112417
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:02:17
channel ORA_DISK_1: starting datafile copy
input datafile fno=00003 name=+DATA/asmdb/datafile/sysaux.257.886430341
output filename=+NEWDG/asmdb/datafile/sysaux.259.888112421 tag=TAG20150819T015122 recid=7 stamp=888112494
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:01:16
channel ORA_DISK_1: starting datafile copy
input datafile fno=00005 name=+DATA/asmdb/datafile/example.265.886430497
output filename=+NEWDG/asmdb/datafile/example.260.888112497 tag=TAG20150819T015122 recid=8 stamp=888112539
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:47
channel ORA_DISK_1: starting datafile copy
input datafile fno=00002 name=+DATA/asmdb/datafile/undotbs1.258.886430341
output filename=+NEWDG/asmdb/datafile/undotbs1.261.888112547 tag=TAG20150819T015122 recid=9 stamp=888112564
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:26
channel ORA_DISK_1: starting datafile copy
input datafile fno=00004 name=+DATA/asmdb/datafile/users.259.886430341
output filename=+NEWDG/asmdb/datafile/users.262.888112571 tag=TAG20150819T015122 recid=10 stamp=888112572
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:03
channel ORA_DISK_1: starting datafile copy
input datafile fno=00006 name=+DATA/asmdb/datafile/tbs1.267.886604335
output filename=+NEWDG/asmdb/datafile/tbs1.263.888112573 tag=TAG20150819T015122 recid=11 stamp=888112580
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:15
channel ORA_DISK_1: starting datafile copy
copying current control file
output filename=+NEWDG/asmdb/controlfile/backup.264.888112589 tag=TAG20150819T015122 recid=12 stamp=888112601
channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:15
channel ORA_DISK_1: starting full datafile backupset
channel ORA_DISK_1: specifying datafile(s) in backupset
including current SPFILE in backupset
channel ORA_DISK_1: starting piece 1 at 19-AUG-15
channel ORA_DISK_1: finished piece 1 at 19-AUG-15
piece handle=+NEWDG/asmdb/backupset/2015_08_19/nnsnf0_tag20150819t015122_0.265.888112607 tag=TAG20150819T015122 comment=NONE
channel ORA_DISK_1: backup set complete, elapsed time: 00:00:02
Finished backup at 19-AUG-15
RMAN> list copy of database;
Key File S Completion Time Ckp SCN Ckp Time Name
------- ---- - --------------- ---------- --------------- ----
6 1 A 19-AUG-15 559320 19-AUG-15 +NEWDG/asmdb/datafile/system.258.888112285
9 2 A 19-AUG-15 559375 19-AUG-15 +NEWDG/asmdb/datafile/undotbs1.261.888112547
7 3 A 19-AUG-15 559349 19-AUG-15 +NEWDG/asmdb/datafile/sysaux.259.888112421
10 4 A 19-AUG-15 559383 19-AUG-15 +NEWDG/asmdb/datafile/users.262.888112571
8 5 A 19-AUG-15 559366 19-AUG-15 +NEWDG/asmdb/datafile/example.260.888112497
11 6 A 19-AUG-15 559385 19-AUG-15 +NEWDG/asmdb/datafile/tbs1.263.888112573
3 6 A 01-AUG-15 514730 01-AUG-15 /home/oracle/tbs1.bak
----拷貝完成
----2.數(shù)據(jù)文件拷貝已經(jīng)完成,我們是在數(shù)據(jù)庫(kù)開(kāi)著的情況下拷貝的,現(xiàn)在需要將數(shù)據(jù)庫(kù)切換到新的文件,切換文件實(shí)際是告訴控制文件,數(shù)據(jù)文件被移到了新的位置。因此這個(gè)步驟只是改變控制文件的內(nèi)容,會(huì)很快,但是需要將數(shù)據(jù)庫(kù)置為mount狀態(tài)
RMAN> switch database to copy;
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of switch to copy command at 08/19/2015 02:00:35
RMAN-06572: database is open and datafile 1 is not offline
----注意,需要啟動(dòng)數(shù)據(jù)庫(kù)到mount狀態(tài)執(zhí)行switch
RMAN> shutdown immediate;
database closed
database dismounted
Oracle instance shut down
RMAN> startup mount
connected to target database (not started)
Oracle instance started
database mounted
Total System Global Area 608174080 bytes
Fixed Size 1220844 bytes
Variable Size 180358932 bytes
Database Buffers 423624704 bytes
Redo Buffers 2969600 bytes
RMAN> switch database to copy;
datafile 1 switched to datafile copy "+NEWDG/asmdb/datafile/system.258.888112285"
datafile 2 switched to datafile copy "+NEWDG/asmdb/datafile/undotbs1.261.888112547"
datafile 3 switched to datafile copy "+NEWDG/asmdb/datafile/sysaux.259.888112421"
datafile 4 switched to datafile copy "+NEWDG/asmdb/datafile/users.262.888112571"
datafile 5 switched to datafile copy "+NEWDG/asmdb/datafile/example.260.888112497"
datafile 6 switched to datafile copy "+NEWDG/asmdb/datafile/tbs1.263.888112573"
----switch成功,數(shù)據(jù)庫(kù)使用新的數(shù)據(jù)文件
RMAN> alter database open;
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of alter db command at 08/19/2015 02:01:54
ORA-01113: file 1 needs media recovery
ORA-01110: data file 1: '+NEWDG/asmdb/datafile/system.258.888112285'
RMAN> recover database;
Starting recover at 19-AUG-15
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=157 devtype=DISK
starting media recovery
media recovery complete, elapsed time: 00:00:02
Finished recover at 19-AUG-15
RMAN> alter database open;
database opened
成功恢復(fù)并打開(kāi)數(shù)據(jù)庫(kù)。
四、將日志文件、臨時(shí)文件、參數(shù)文件等遷移到新的磁盤(pán)組
控制文件和數(shù)據(jù)文件已經(jīng)成功移動(dòng),日志文件、臨時(shí)文件、參數(shù)文件需要移動(dòng)
遷移步驟:如下:
1. 查看數(shù)據(jù)文件是否正常,并且修改參數(shù)使以后新的文件放在+newdg上
SQL> select name from v$datafile;
NAME
--------------------------------------------------------------------------------
+NEWDG/asmdb/datafile/system.258.888112285
+NEWDG/asmdb/datafile/undotbs1.261.888112547
+NEWDG/asmdb/datafile/sysaux.259.888112421
+NEWDG/asmdb/datafile/users.262.888112571
+NEWDG/asmdb/datafile/example.260.888112497
+NEWDG/asmdb/datafile/tbs1.263.888112573
6 rows selected.
----查看數(shù)據(jù)文件是否正常
SQL> show parameter create
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
create_bitmap_area_size integer 8388608
create_stored_outlines string
db_create_file_dest string +DATA
db_create_online_log_dest_1 string
db_create_online_log_dest_2 string
db_create_online_log_dest_3 string
db_create_online_log_dest_4 string
db_create_online_log_dest_5 string
SQL> alter system set db_create_file_dest ='+newdg';
----以后新的文件都生成在新的磁盤(pán)組
System altered.
----添加臨時(shí)文件
SQL> select name from v$tempfile;
NAME
--------------------------------------------------------------------------------
+DATA/asmdb/tempfile/temp.264.886430485
SQL> create temporary tablespace temp01 tempfile size 20M;
Tablespace created.
SQL> SQL> select name from v$tempfile;
NAME
--------------------------------------------------------------------------------
+DATA/asmdb/tempfile/temp.264.886430485
+NEWDG/asmdb/tempfile/temp01.266.888113011
SQL> drop tablespace temp including contents and datafiles;
drop tablespace temp including contents and datafiles
*
ERROR at line 1:
ORA-12906: cannot drop default temporary tablespace
SQL> alter database default temporary tablespace temp01;
----舊的臨時(shí)表空間是系統(tǒng)默認(rèn)臨時(shí)表空間,無(wú)法刪除,修改后刪除舊的
Database altered.
SQL> drop tablespace temp including contents and datafiles;
Tablespace dropped.
3. 日志文件:在新磁盤(pán)添加新成員,刪除舊成員
----查看日志組狀況
SQL> select * from v$log;
GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS
---------- ---------- ---------- ---------- ---------- --- ----------------
FIRST_CHANGE# FIRST_TIM
------------- ---------
1 1 5 52428800 1 NO CURRENT
559083 19-AUG-15
2 1 3 52428800 1 YES INACTIVE
507040 01-AUG-15
3 1 4 52428800 1 YES INACTIVE
537744 19-AUG-15
----有三個(gè)組,給每個(gè)組添加新成員
SQL> alter database add logfile member '+newdg' to group 1;
Database altered.
SQL> alter database add logfile member '+newdg' to group 2;
Database altered.
SQL> alter database add logfile member '+newdg' to group 3;
Database altered.
SQL> alter system switch logfile;
System altered.
SQL> /
System altered.
SQL> /
System altered.
SQL> /
System altered.
----多次切換日志,至少一輪
SQL> select member from v$logfile;
MEMBER
--------------------------------------------------------------------------------
+DATA/asmdb/onlinelog/group_3.263.886430465
+DATA/asmdb/onlinelog/group_2.262.886430459
+DATA/asmdb/onlinelog/group_1.261.886430455
+NEWDG/asmdb/onlinelog/group_1.267.888113109
+NEWDG/asmdb/onlinelog/group_2.268.888113113
+NEWDG/asmdb/onlinelog/group_3.269.888113115
6 rows selected.
----新成員添加成功
SQL> alter database drop logfile member'+DATA/asmdb/onlinelog/group_3.263.886430465';
Database altered.
SQL> alter database drop logfile member'+DATA/asmdb/onlinelog/group_2.262.886430459';
alter database drop logfile member'+DATA/asmdb/onlinelog/group_2.262.886430459'
*
ERROR at line 1:
ORA-01609: log 2 is the current log for thread 1 - cannot drop members
ORA-00312: online log 2 thread 1: '+DATA/asmdb/onlinelog/group_2.262.886430459'
ORA-00312: online log 2 thread 1:
'+NEWDG/asmdb/onlinelog/group_2.268.888113113'
----正在使用的不能刪除,先刪除非current,切換日志后再刪除該成員
SQL> alter database drop logfile member'+DATA/asmdb/onlinelog/group_1.261.886430455';
Database altered.
SQL> alter system switch logfile;
System altered.
SQL> alter database drop logfile member'+DATA/asmdb/onlinelog/group_2.262.886430459';
Database altered.
SQL> select member from v$logfile;
MEMBER
--------------------------------------------------------------------------------
+NEWDG/asmdb/onlinelog/group_1.267.888113109
+NEWDG/asmdb/onlinelog/group_2.268.888113113
+NEWDG/asmdb/onlinelog/group_3.269.888113115
----新成員添加成功,舊成員刪除成功
4. 參數(shù)文件:
利用spfile生成pfile,pfile生成新的spfile,最后將pfile指向新的spfile
----查看參數(shù)文件
SQL> show parameter spfile
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
spfile string +DATA/asmdb/spfileasmdb.ora
SQL> create pfile from spfile;
創(chuàng)建pfile
File created.
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> create spfile='+newdg/asmdb/spfileasmdb.ora' from pfile;
----利用pfile生成新的spfile
File created.
SQL> !
[oracle@oracle4 dbs]$ vi initasmdb.ora
spfile='+newdg/asmdb/spfileasmdb.ora'
----pfile指向新的spfile
SQL> startup force
ORACLE instance started.
Total System Global Area 608174080 bytes
Fixed Size 1220844 bytes
Variable Size 180358932 bytes
Database Buffers 423624704 bytes
Redo Buffers 2969600 bytes
Database mounted.
Database opened.
SQL>
----新參數(shù)文件添加成功,舊參數(shù)文件刪除成功
五、檢查
----檢查
show parameter spfile;
select name from v$controlfile;
select name from v$datafile;
select name from v$tempfile;
select member from v$logfile;
select filename from v$block_change_tracking;
select name from v$flashback_database_logfile;
SQL> show parameter pfile
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
spfile string +NEWDG/asmdb/spfileasmdb.ora
SQL> select name from v$controlfile;
NAME
--------------------------------------------------------------------------------
+NEWDG/asmdb/controlfile/backup.257.888112073
SQL> select name from v$datafile;
NAME
--------------------------------------------------------------------------------
+NEWDG/asmdb/datafile/system.258.888112285
+NEWDG/asmdb/datafile/undotbs1.261.888112547
+NEWDG/asmdb/datafile/sysaux.259.888112421
+NEWDG/asmdb/datafile/users.262.888112571
+NEWDG/asmdb/datafile/example.260.888112497
+NEWDG/asmdb/datafile/tbs1.263.888112573
6 rows selected.
SQL> select name from v$tempfile;
NAME
--------------------------------------------------------------------------------
+NEWDG/asmdb/tempfile/temp01.266.888113011
SQL> select member from v$logfile;
MEMBER
--------------------------------------------------------------------------------
+NEWDG/asmdb/onlinelog/group_1.267.888113109
+NEWDG/asmdb/onlinelog/group_2.268.888113113
+NEWDG/asmdb/onlinelog/group_3.269.888113115
SQL> select name from v$flashback_database_logfile;
no rows selected
SQL> select filename from v$block_change_tracking;
以上是“如何修改ASM磁盤(pán)冗余度”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!