博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle 12c DBCA浅析(r12笔记第48天)
阅读量:6702 次
发布时间:2019-06-25

本文共 6041 字,大约阅读时间需要 20 分钟。

   我们知道在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

转载地址:http://vkzlo.baihongyu.com/

你可能感兴趣的文章
红帽公司即将进军OpenStack网络融合工作
查看>>
警告:非智能手机可入侵核电站的物理隔绝设备
查看>>
CTO下午茶:化繁为简,面面俱到
查看>>
游戏安全资讯精选 2017年 第七期:游戏账号窃取日益猖獗,Struts2 REST插件远程执行命令漏洞全面分析,2017世界物联网博览会IoT安全观点...
查看>>
项立刚:FDD牌照发放 难改行业大格局
查看>>
移动广告作弊流量超过30%?你中招了吗
查看>>
CentOS 6.5环境 MongoDB 3.2.8 单实例安装部署
查看>>
基于阿里云MaxCompute实现复杂事件检测
查看>>
一键部署自动感知服务的Docker集群(一)
查看>>
【D3.js 学习总结】17、D3布局-分区图(矩形)
查看>>
《C语言及程序设计》实践项目——数组与指针
查看>>
MySQL中char和varchar有啥区别?优缺点是啥?
查看>>
PostgreSQL的函数安全定义解说
查看>>
pageinspect介绍
查看>>
C++语言基础 例程 类声明和成员函数定义的分离
查看>>
剑指offer学习笔记2
查看>>
面向对象
查看>>
动态分配的顺序线性表的十五种操作—C语言实现
查看>>
解决海量数据计算、降低企业成本的利器——MaxCompute
查看>>
JPEG编码
查看>>