12c 练习日记4 pluggable database plug(unplug)data migration
12c实验记录4:现在 很多生产环境多个业务模块集成到一个数据库中,但是系统共用模块一旦出问题将会影响所有业务的运行,这是最大的一个弊端,对于这种情况,12c 推出了 pluggable 完美的解决了这个问题,而且简化了 data migration 的操作。下面是我CRT保存的实验记录。SQL> SQL> show parameter name;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
cell_offloadgroup_name string
db_file_name_convert string
db_name string orcl12c
db_unique_name string orcl12c
global_names boolean FALSE
instance_name string orcl12c
lock_name_space string
log_file_name_convert string
pdb_file_name_convert string
processor_group_name string
service_names string orcl12c
SQL>
SQL> show con_id con_name
CON_ID
------------------------------
1
CON_NAME
------------------------------
CDB$ROOT
SQL> show pdbs;
CON_ID CON_NAME OPEN MODERESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLYNO
3 TEST MOUNTED
SQL>
SQL> select con_id,name,open_mode,dbid from v$pdbs;
CON_ID NAME OPEN_MODE DBID
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLY 315034528
3 TEST MOUNTED 2925957051
SQL> alter pluggable database test open;
Pluggable database altered.
SQL> alter session set container=test;
Session altered.
SQL> show con_name
CON_NAME
------------------------------
TEST
Connected to:
Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
SQL> col file_name for a20
FILE_NAME FILE_ID TABLESPACE_NAME
-------------------- ---------- ------------------------------
/oradata/orcl12c/sys 1 SYSTEM
tem01.dbf
/oradata/orcl12c/sys 3 SYSAUX
aux01.dbf
/oradata/orcl12c/use 6 USERS
rs01.dbf
/oradata/orcl12c/und 4 UNDOTBS1
otbs01.dbf
FILE_NAME FILE_ID TABLESPACE_NAME
-------------------- ---------- ------------------------------
SQL> create pluggable database pdb1 admin user pdb1 identified by oracle; ------OMF 模式才能 这么用
create pluggable database pdb1 admin user pdb1 identified by oracle
*
ERROR at line 1:
ORA-65016: FILE_NAME_CONVERT must be specified
SQL> conn / as sysdba
/Connected.
SQL>
create pluggable database pdb1 admin user pdb1 identified by oracle
*
ERROR at line 1:
ORA-65016: FILE_NAME_CONVERT must be specified
SQL> create pluggable database pdb1 admin user pdb identified by oracle storage (maxsize 2G max_shared_temp_size 100m) default tablespace testdb datafile '/oradata/orcl12c/test/testdb.dbf' size 25m autoextend on path_prefix = '/oradata/orcl12c/test/' file_name_convert=('/oradata/orcl12c/pdbseed','/oradata/orcl12c/test/');
create pluggable database pdb1 admin user pdb identified by oracle storage (maxsize 2G max_shared_temp_size 100m) default tablespace testdb datafile '/oradata/orcl12c/test/testdb.dbf' size 25m autoextend on path_prefix = '/oradata/orcl12c/test/' file_name_convert=('/oradata/orcl12c/pdbseed','/oradata/orcl12c/test/')
*
ERROR at line 1:
ORA-01537: cannot add file '/oradata/orcl12c/test//system01.dbf' - file already
part of database
SQL> show pdbs
CON_ID CON_NAME OPEN MODERESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLYNO
3 TEST MOUNTED
SQL> alter pluggable database test open;
Pluggable database altered.
SQL> show parameter create
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
create_bitmap_area_size integer 8388608
create_stored_outlines string
db_create_file_dest string
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>
SQL>
SQL> show pdbs
CON_ID CON_NAME OPEN MODERESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLYNO
3 TEST READ WRITE NO
SQL> show user
USER is "SYS"
SQL> show con_name
CON_NAME
------------------------------
CDB$ROOT
SQL>
SQL> alter pluggable database test close immediate;
Pluggable database altered.
SQL> show pdbs
CON_ID CON_NAME OPEN MODERESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLYNO
3 TEST MOUNTED
SQL> alter pluggable database test unplug into '/tmp/test.xml';
Pluggable database altered.
SQL> drop pluggable database test including datafiles;
Pluggable database dropped.
SQL> show user
USER is "SYS"
SQL> show parameter pdb
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
pdb_file_name_convert string
pdb_lockdown string
pdb_os_credential string
SQL>
SQL> show pdbs
CON_ID CON_NAME OPEN MODERESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLYNO
SQL>
SQL>
SQL> create pluggable database pdb1 admin user pdb1 identified by oracle storage (maxsize 2G max_shared_temp_size 100M) default tablespace testdb datafile '/oradata/orcl12c/test/testdb.dbf' size 25m autoextend on path_prefix='/oradata/orcl12/test' file_name_convert=('/oradata/orcl12c/pdbseed/','/oradata/orcl12c/test');
Pluggable database created.
SQL> select pdb_id,pdb_name,dbid,status,creation_scn from dba_pdbs;
PDB_ID
----------
PDB_NAME
--------------------------------------------------------------------------------
DBID STATUS CREATION_SCN
---------- --------- ------------
2
PDB$SEED
315034528 NORMAL 1594471
3
PDB1
2270947164 NEW 1746873
PDB_ID
----------
PDB_NAME
--------------------------------------------------------------------------------
DBID STATUS CREATION_SCN
---------- --------- ------------
SQL> col pdb_name for a30
SQL> /
PDB_ID PDB_NAME DBID STATUS CREATION_SCN
---------- ------------------------------ ---------- --------- ------------
2 PDB$SEED 315034528 NORMAL 1594471
3 PDB1 2270947164 NEW 1746873
SQL> l
1* select pdb_id,pdb_name,dbid,status,creation_scn from dba_pdbs
SQL>
SQL> select con_id,dbid,open_mode from v$pdbs;
CON_ID DBID OPEN_MODE
---------- ---------- ----------
2315034528 READ ONLY
3 2270947164 MOUNTED
SQL> alter pluggable database pdb1 open;
Pluggable database altered.
SQL> select con_id,dbid,open_mode from v$pdbs;
CON_ID DBID OPEN_MODE
---------- ---------- ----------
2315034528 READ ONLY
3 2270947164 READ WRITE
SQL> alter pluggable database pdb1 close immediate;
Pluggable database altered.
SQL> alter pluggable database pdb1 unplug into '/tmp/pdb1.xml';
Pluggable database altered.
】SQL> drop pluggable database pdb1 including datafiles;
Pluggable database dropped.
SQL> create pluggable database pdb1 admin user pdb1 identified by oracle storage (maxsize 2G max_shared_temp_size 100M) default tablespace testdb datafile '/oradata/orcl12c/test/testdb.dbf' size 25m autoextend on path_prefix='/oradata/orcl12c/test' file_name_convert=('/oradata/orcl12c/pdbseed/','/oradata/orcl12c/test');
Pluggable database created.
SQL> alter pluggable database all open;
Pluggable database altered.
SQL> alter session set container=pdb1;
Session altered.
SQL> select file_name,file_id,tablespace_name from dba_data_files;
FILE_NAME FILE_ID TABLESPACE_NAME
-------------------- ---------- ------------------------------
/oradata/orcl12c/tes 15 SYSTEM
tsystem01.dbf
/oradata/orcl12c/tes 16 SYSAUX
tsysaux01.dbf
/oradata/orcl12c/tes 17 TESTDB
t/testdb.dbf
SQL> select open_mode,name from v$database;
OPEN_MODE NAME
-------------------- ---------
READ WRITE ORCL12C
SQL> show user;
USER is "SYS"
SQL> show con_name
CON_NAME
------------------------------
PDB1
SQL> conn / as sysdba
Connected.
SQL> show con_name
CON_NAME
------------------------------
CDB$ROOT
SQL> select open_mode,name,con_id from v$pdbs;
OPEN_MODENAME CON_ID
---------- ------------------------------ ----------
READ ONLYPDB$SEED 2
READ WRITE PDB1 3
SQL> conn / as sysdba
Connected.
SQL> startup force;
ORACLE instance started.
Total System Global Area838860800 bytes
Fixed Size 2929936 bytes
Variable Size 562039536 bytes
Database Buffers 268435456 bytes
Redo Buffers 5455872 bytes
show Database mounted.
con_name con_id
Database opened.
SQL>
CON_NAME
------------------------------
CDB$ROOT
CON_ID
------------------------------
1
SQL> alter session set container=pdb1
2;
Session altered.
SQL> show pdbs
CON_ID CON_NAME OPEN MODERESTRICTED
---------- ------------------------------ ---------- ----------
3 PDB1 MOUNTED
SQL> show pdb
SP2-0158: unknown SHOW option "pdb"
SQL> show con_name
CON_NAME
------------------------------
PDB1
SQL> alter database open;
select file_name from dba_data_files;
select name from v$datafiles;
Database altered.
SQL>
FILE_NAME
--------------------
/oradata/orcl12c/tes
tsystem01.dbf
/oradata/orcl12c/tes
tsysaux01.dbf
/oradata/orcl12c/tes
t/testdb.dbf
SQL> col file_name for a50
SQL> select file_name,tablespace_name from dba_data_files;
FILE_NAME
--------------------------------------------------
TABLESPACE_NAME
------------------------------
/oradata/orcl12c/testsystem01.dbf
SYSTEM
/oradata/orcl12c/testsysaux01.dbf
SYSAUX
/oradata/orcl12c/test/testdb.dbf
TESTDB
SQL> shutdown immediate
SQL> drop pluggable database pdb1 including datafiles;
Pluggable database dropped.
SQL> create pluggable database pdb1 admin user pdb1 identified by oracle storage (maxsize 2G max_shared_temp_size 100M) default tablespace testdb datafile '/oradata/orcl12c/test/testdb.dbf' size 25m autoextend on path_prefix='/oradata/orcl12c/test/' file_name_convert=('/oradata/orcl12c/pdbseed/','/oradata/orcl12c/test/');
Pluggable database created.
SQL> alter pluggable database pdb1 unplug into '/tmp/pdb1.xml';
alter pluggable database pdb1 unplug into '/tmp/pdb1.xml'
*
ERROR at line 1:
ORA-65170: XML file /tmp/pdb1.xml already exists
Pluggable database altered.
SQL> alter pluggable database pdb1 open;
alter pluggable database pdb1 open
*
ERROR at line 1:
ORA-65086: cannot open/close the pluggable database
SQL> select name,cdb from v$database;
NAME CDB
--------- ---
ORCL12C YES
SQL> create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/)';
create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/)'
*ERROR at line 1:ORA-02000: missing ) keyword
SQL> reate pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=
SQL> create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/');
create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/')
*
ERROR at line 1:
ORA-65139: Mismatch between XML metadata file and data file
/oradata/orcl12c/test/system01.dbf for value of guid
(2EA15526B43222B5E0530100007F4249 in the plug XML file,
2EB115F0AE9C19BEE0530100007FAF6D in the data file)
1* create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/')
SQL> create pluggable database pdb2 using '/tmp/pdb1.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/')
2;
create pluggable database pdb2 using '/tmp/pdb1.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/')
*
ERROR at line 1:
ORA-65122: Pluggable database GUID conflicts with the GUID of an existing
container.
SQL> drop pluggable database pdb1;
Pluggable database dropped.
SQL> create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/');
create pluggable database pdb2 using '/tmp/test.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/')
*
ERROR at line 1:
ORA-65139: Mismatch between XML metadata file and data file
/oradata/orcl12c/test/system01.dbf for value of guid
(2EA15526B43222B5E0530100007F4249 in the plug XML file,
2EB115F0AE9C19BEE0530100007FAF6D in the data file)
SQL> create pluggable database pdb2 using '/tmp/pdb1.xml' copy file_name_convert=('/oradata/orcl12c/test/','/oradata/orcl12c/pdb2/');
Pluggable database created.
SQL> SQL> SQL>
SQL> exec dbms_pdb.sync_pdb();
PL/SQL procedure successfully completed.
SQL> select con_id,dbid,name,open_mode from v$pdbs;
CON_ID DBID NAME OPEN_MODE
---------- ---------- ------------------------------ ----------
2315034528 PDB$SEED READ ONLY
3 3710433175 PDB2 MOUNTED
SQL> show con_name
CON_NAME
------------------------------
CDB$ROOT
SQL> alter pluggable database pdb2 UNPLUG into '/tmp/pdb2.xml';
alter pluggable database pdb2 UNPLUG into '/tmp/pdb2.xml'
*
ERROR at line 1:
ORA-65170: XML file /tmp/pdb2.xml already exists
Pluggable database altered.
SQL> alter pluggable database pdb2 open;
alter pluggable database pdb2 open
*
ERROR at line 1:
ORA-65086: cannot open/close the pluggable database
SQL> drop pluggable database pdb2;
Pluggable database dropped.
SQL> show con_id con_name
CON_ID
------------------------------
1
CON_NAME
------------------------------
CDB$ROOT
SQL> select con_id,name,open_mode from v$pdbs;
CON_ID NAME OPEN_MODE
---------- ------------------------------ ----------
2 PDB$SEED READ ONLY
SQL> create pluggable database pdb3 using '/tmp/pdb2.xml' copy file_name_convert=('/oradata/orcl12c/pdb2/','/oradata/orcl12c/pdb3/');
Pluggable database created.
SQL> select con_id,open_mode,name from v$pdbs;
CON_ID OPEN_MODENAME
---------- ---------- ------------------------------
2 READ ONLYPDB$SEED
3 MOUNTED PDB3
SQL> alter session set container=pdb3;
Session altered.
SQL> show con_name;
CON_NAME
------------------------------
PDB3
SQL> alter database open;
select con_id,open_mode,name from v$pdbs;
Database altered.
SQL>
CON_ID OPEN_MODENAME
---------- ---------- ------------------------------
3 READ WRITE PDB3
SQL> shutdown immediate;
Pluggable Database closed.
SQL> show con_name
CON_NAME
------------------------------
PDB3
SQL>
SQL> conn / as sysdba
Connected.
SQL> show con_name
CON_NAME
------------------------------
CDB$ROOT
来源: http://blog.sina.com.cn/s/blog_1442877660102vzng.html
页:
[1]