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
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
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23718752/viewspace-2138192/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL service啟動指令碼淺析(r12筆記第59天)MySql指令碼筆記
- MySQL中的binlog和redo淺析(r12筆記第5天)MySql筆記
- Oracle 12c PDB淺析Oracle
- Oracle 12c中DBCA搭建備庫體驗(r11筆記第92天)Oracle筆記
- Oracle 12c PDB淺析(二)Oracle
- Vuex 原理淺析筆記Vue筆記
- Oracle閃回原理測試(三)(r12筆記第16天)Oracle筆記
- MySQL引數對比淺析(r11筆記第97天)MySql筆記
- 一種Oracle快速的整合遷移方案(r12筆記第98天)Oracle筆記
- MySQL中的derived table(r12筆記第47天)MySql筆記
- 歸零的心態(r12筆記第82天)筆記
- mysqlpump的效能測試(r12筆記第89天)MySql筆記
- 相同update語句在MySQL,Oracle的不同表現(r12筆記第30天)MySqlOracle筆記
- webrtc QOS筆記四 Nack機制淺析Web筆記
- 我爸爸眼中的我(r12筆記第22天)筆記
- 一個IT人和ppt的故事(r12筆記第39天)筆記
- 我的女兒二三事(七)(r12筆記第58天)筆記
- 玩足彩的一點感受(r12筆記第80天)筆記
- MySQL原始碼安裝總結(r12筆記第12天)MySql原始碼筆記
- sandbox和MHA快速測試(r12筆記第32天)筆記
- mysqldump的一點使用總結(r12筆記第81天)MySql筆記
- 駕考的一點總結(r12筆記第93天)筆記
- oracle的TAF淺析Oracle
- MySQL傳輸表空間小結(r12筆記第2天)MySql筆記
- 推薦最近收藏的幾篇文章(r12筆記第85天)筆記
- mysqlpump和mysqldump的效能大比拼(r12筆記第90天)MySql筆記
- Oracle 12c資料字典的小問題(r11筆記第49天)Oracle筆記
- Oracle Xmltype型別淺析OracleXML型別
- 第 57 期 sync/semaphore 原始碼淺析原始碼
- 關於金錢的幾個小故事(r12筆記第8天)筆記
- MySQL自增列的重複值問題(r12筆記第25天)MySql筆記
- MySQL無法建立表的問題分析(r12筆記第73天)MySql筆記
- 《SharedPreferences的使用及原始碼淺析》讀書筆記原始碼筆記
- 使用pt工具檢測MySQL主從延遲(r12筆記第7天)MySql筆記
- 在eclipse中配置MySQL原始碼環境(r12筆記第14天)EclipseMySql原始碼筆記
- 心理學中的效應簡單解讀(r12筆記第24天)筆記
- 分分鐘搭建MySQL一主多從環境(r12筆記第31天)MySql筆記
- 資料架構難點-資料分佈(r12筆記第43天)架構筆記