百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

Oracle 12c DBCA浅析(r12笔记第48天)

sinye56 2024-10-08 16:41 3 浏览 0 评论

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


相关推荐

Linux基础知识之修改root用户密码

现象:Linux修改密码出现:Authenticationtokenmanipulationerror。故障解决办法:进入单用户,执行pwconv,再执行passwdroot。...

Linux如何修改远程访问端口

对于Linux服务器而言,其默认的远程访问端口为22。但是,出于安全方面的考虑,一般都会修改该端口。下面我来简答介绍一下如何修改Linux服务器默认的远程访问端口。对于默认端口而言,其相关的配置位于/...

如何批量更改文件的权限

如果你发觉一个目录结构下的大量文件权限(读、写、可执行)很乱时,可以执行以下两个命令批量修正:批量修改文件夹的权限chmod755-Rdir_name批量修改文件的权限finddir_nam...

CentOS「linux」学习笔记10:修改文件和目录权限

?linux基础操作:主要介绍了修改文件和目录的权限及chown和chgrp高级用法6.chmod修改权限1:字母方式[修改文件或目录的权限]u代表所属者,g代表所属组,o代表其他组的用户,a代表所有...

Linux下更改串口的权限

问题描述我在Ubuntu中使用ArduinoIDE,并且遇到串口问题。它过去一直有效,但由于可能不必要的原因,我觉得有必要将一些文件的所有权从root所有权更改为我的用户所有权。...

Linux chown命令:修改文件和目录的所有者和所属组

chown命令,可以认为是"changeowner"的缩写,主要用于修改文件(或目录)的所有者,除此之外,这个命令也可以修改文件(或目录)的所属组。当只需要修改所有者时,可使用...

chmod修改文件夹及子目录权限的方法

chmod修改文件夹及子目录权限的方法打开终端进入你需要修改的目录然后执行下面这条命令chmod777*-R全部子目录及文件权限改为777查看linux文件的权限:ls-l文件名称查看li...

Android 修改隐藏设置项权限

在Android系统中,修改某些隐藏设置项或权限通常涉及到系统级别的操作,尤其是针对非标准的、未在常规用户界面显示的高级选项。这些隐藏设置往往与隐私保护、安全相关的特殊功能有关,或者涉及开发者选项、权...

完蛋了!我不小心把Linux所有的文件权限修改了!在线等修复!

最近一个客户在群里说他一不小心把某台业务服务器的根目录权限给改了,本来想修改当前目录,结果执行成了根目录。...

linux改变安全性设置-改变所属关系

CentOS7.3学习笔记总结(五十八)-改变安全性设置-改变所属关系在以前的文章里,我介绍过linux文件权限,感兴趣的朋友可以关注我,阅读一下这篇文章。这里我们不在做过的介绍,注重介绍改变文件或者...

Python基础到实战一飞冲天(一)--linux基础(七)修改权限chmod

#07_Python基础到实战一飞冲天(一)--linux基础(七)--修改权限chmod-root-groupadd-groupdel-chgrp-username-passwd...

linux更改用户权限为root权限方法大全

背景在使用linux系统时,经常会遇到需要修改用户权限为root权限。通过修改用户所属群组groupid为root,此操作只能使普通用户实现享有部分root权限,普通用户仍不能像root用户一样享有超...

怎么用ip命令在linux中添加路由表项?

在Linux中添加路由表项,可以使用ip命令的route子命令。添加路由表项的基本语法如下:sudoiprouteadd<network>via<gateway>这...

Linux配置网络

1、网卡名配置相关文件回到顶部网卡名命名规则文件:/etc/udev/rules.d/70-persistent-net.rules#PCIdevice0x8086:0x100f(e1000)...

Linux系列---网络配置文件

1.网卡配置文件在/etc/sysconfig/network-scripts/下:[root@oldboynetwork-scripts]#ls/etc/sysconfig/network-s...

取消回复欢迎 发表评论: