1. 程式人生 > 其它 >Oracle 12c DBCA淺析(r12筆記第48天)

Oracle 12c DBCA淺析(r12筆記第48天)

我們知道在11g的環境中我們可以通過一些分析來得到DBCA的一些後臺處理工作,有一點需要說明的是,如果一個12c的單例項資料庫需要轉換為12c的容器資料庫,你去檢視官方文件,會發現這是一個空白,不是做不了,而是裡面有一些地方會干擾到你。

所以在11g手工探究指令碼過程的基礎上,12c的部分你需要再進一步。常規來說,我們可以通過如下的命令得到一個12c的資料庫建立的指令碼。

dbca -silent -templateName $ORACLE_HOME/assistants/dbca/templates/General_Purpose.dbc -gdbname testdb1 -sid testdb1 -characterSet ZHS16GBK -sysPassword oracle -systemPassword oracle -createAsContainerDatabase true

-generateScripts

這個過程會建立一系列的指令碼。

我們分為幾個步驟來說。

初始化非容器資料庫

假設我們建立的資料庫為dbcadb。

我們可以通過下面的步驟來初始化預設的資料庫,因為rman裡面是seeddata,我們後期可以修改dbname為dbcadb

$ vi initseeddata.ora db_name=seeddata control_files=/U01/app/oracle/oradata/dbcadb/control01.ctl sga_target=800M enable_pluggable_database=true

我們切換到下面的目錄,就是dbca的大本營。 $ cd $ORACLE_HOME/assistants/dbca/templates/ 引數檔案解決了,控制檔案怎麼辦呢,dbca的目錄下是有一個.ctl檔案的,直接拿來就可以用。

$ cp Seed_Database.ctl $ORACLE_BASE/oradata/dbcadb/control01.ctl

下面的這一步很關鍵,能夠正常啟動,能夠識別容器的引數。

SQL> alter database mount; Database altered.

修改redo,預設的路徑是不可用的,我們修改一下。

SQL> select member from v$logfile; MEMBER -------------------------------------------------------------------------------- /ade/b/2717506464/oracle/oradata/seeddata/redo01.log

/ade/b/2717506464/oracle/oradata/seeddata/redo02.log /ade/b/2717506464/oracle/oradata/seeddata/redo03.log

修改為自己設定的路徑即可。

SQL> alter database rename file '/ade/b/2717506464/oracle/oradata/seeddata/redo01.log' to '/U01/app/oracle/oradata/dbcadb/redo01.log'; SQL>alter database rename file '/ade/b/2717506464/oracle/oradata/seeddata/redo02.log' to '/U01/app/oracle/oradata/dbcadb/redo02.log'; SQL>alter database rename file '/ade/b/2717506464/oracle/oradata/seeddata/redo03.log' to '/U01/app/oracle/oradata/dbcadb/redo03.log';

資料檔案怎麼辦呢。我們需要從備份中還原恢復。 $ rman target / RMAN> catalog start with '/U01/app/oracle/product/12.2/assistants/dbca/templates/Seed_Database.dfb'; using target database control file instead of recovery catalog searching for all files that match the pattern /U01/app/oracle/product/12.2/assistants/dbca/templates/Seed_Database.dfb

識別出這個備份之後我們用下面的命令來做還原和恢復。 run{ set newname for datafile 1 to '/U01/app/oracle/oradata/dbcadb/system01.dbf'; set newname for datafile 3 to '/U01/app/oracle/oradata/dbcadb/sysaux01.dbf'; set newname for datafile 4 to '/U01/app/oracle/oradata/dbcadb/undotbs01.dbf'; set newname for datafile 7 to '/U01/app/oracle/oradata/dbcadb/users01.dbf'; restore database; switch datafile all; recover database; }

整個過程最後會以一個基於SCN的不完全恢復結束。 starting media recovery RMAN-08187: warning: media recovery until SCN 1408557 complete Finished recover at 2017-04-23 18:43:59

這樣一個數據庫open以後就是可用的了。

SQL> alter database open resetlogs; Database altered.

不過需要注意的是這個時候雖然是容器資料庫,但是沒有任何容器的配置,比如seed db,show pdbs沒有任何輸出。

SQL> select cdb from v$database; CDB ------ YES SQL> show pdbs; SQL>

然後我們來處理臨時檔案。

SQL> select file_name from dba_temp_files; select file_name from dba_temp_files * ERROR at line 1: ORA-01157: cannot identify/lock data file 201 - see DBWR trace file ORA-01110: data file 201: '/ade/b/2717506464/oracle/oradata/seeddata/temp01.dbf'

我們修復一下。 SQL> alter tablespace temp add tempfile '/U01/app/oracle/oradata/dbcadb/temp01.dbf' size 100M; SQL> alter tablespace temp drop tempfile '/ade/b/2717506464/oracle/oradata/seeddata/temp01.dbf';

修改db name

前面的過程完成之後,我們接下來需要做的就是修改db name

startup mount $ nid target=sys/oracle dbname=dbcadb。。。 日誌輸出若干行之後,就成功修改了。

Succesfully changed database name and ID. DBNEWID - Completed succesfully.

我們修改引數檔案。 $ vi initdbcadb.ora db_name=dbcadb control_files=/U01/app/oracle/oradata/dbcadb/control01.ctl sga_target=800M enable_pluggable_database=true

重新設定 ORACLE_SID之後,這個初始化就告一段落。

$ export ORACLE_SID=dbcadb startup nomount alter database mount; alter database open resetlogs;

初始化容器設定

容器的初始化比較特別,可以參考下面的步驟。 mkdir -p /U01/app/oracle/oradata/dbcadb/pdbseed alter system set "_catalog_foreign_restore"=TRUE; alter system set "_restore_create_directory"=TRUE;

我們使用RMAN來做還原。 rman target / run { set command id to 'PDB$SEED'; RESTORE FOREIGN DATAFILE 2 FORMAT '/U01/app/oracle/oradata/dbcadb/pdbseed/system01.dbf',4 FORMAT '/U01/app/oracle/oradata/dbcadb/pdbseed/sysaux01.dbf',9 FORMAT '/U01/app/oracle/oradata/dbcadb/pdbseed/undotbs01.dbf' FROM BACKUPSET '/U01/app/oracle/product/12.2/assistants/dbca/templates/pdbseed.dfb' ; }

上面的指令碼很有特點。需要好好琢磨下,重置設定。 alter system set "_catalog_foreign_restore"=FALSE; alter system set "_restore_create_directory"=FALSE; alter session set "_oracle_script"=TRUE;

接下來是重頭戲。建立PDB SEED CREATE PLUGGABLE DATABASE PDB$SEED AS CLONE USING '/U01/app/oracle/product/12.2/assistants/dbca/templates/pdbseed.xml' source_file_name_convert = ('/ade/b/2717506464/oracle/oradata/seeddata/pdbseed/system01.dbf','/U01/app/oracle/oradata/dbcadb/pdbseed/system01.dbf', '/ade/b/2717506464/oracle/oradata/seeddata/pdbseed/sysaux01.dbf','/U01/app/oracle/oradata/dbcadb/pdbseed/sysaux01.dbf', '/ade/b/2717506464/oracle/oradata/seeddata/pdbseed/undotbs01.dbf','/U01/app/oracle/oradata/dbcadb/pdbseed/undotbs01.dbf', '/ade/b/2717506464/oracle/oradata/seeddata/pdbseed/temp01.dbf','/U01/app/oracle/oradata/dbcadb/pdbseed/temp012017-04-27_14-12-21-103-PM.dbf') NOCOPY STORAGE ( MAXSIZE UNLIMITED MAX_SHARED_TEMP_SIZE UNLIMITED);這個過程是核心的部分。 這個時候檢視pdb,seed是mount狀態,我們可以重置一下,就需要啟動,然後置為read only

CON_ID CON_NAME OPEN MODE RESTRICTED ---------- ------------------------------ ---------- ---------- 2 PDB$SEED MOUNTED

重置seed pdb SQL> alter pluggable database pdb$seed open; Pluggable database altered. SQL> show pdbs; CON_ID CON_NAME OPEN MODE RESTRICTED ---------- ------------------------------ ---------- ---------- 2 PDB$SEED READ WRITE NO SQL> alter session set container=pdb$seed; Session altered. SQL> shutdown immediate Pluggable Database closed. SQL> alter database open read only; Database altered. startup

簡單驗證一下,建立一個PDB. SQL> CREATE PLUGGABLE DATABASE test_pdb ADMIN USER pdb_mgr IDENTIFIED BY oracle file_name_convert=('/U01/app/oracle/oradata/dbcadb','/U01/app/oracle/oradata/dbcadb/test_pdb');

輸出就是我們預期的了。

SQL> show pdbs; CON_ID CON_NAME OPEN MODE RESTRICTED ---------- ------------------------------ ---------- ---------- 2 PDB$SEED READ ONLY NO 3 TEST_PDB MOUNTED