当前位置: 首页 >> 技术文章 >> 从Oracle到PostgreSQL:最全控制文件(上)
从Oracle到PostgreSQL:最全控制文件(上)
发布时间:2019-08-15 发布人:李思雷 1216


导读:本文介绍了Oracle和PostgreSQL控制文件基本内容,对如何重建PostgreSQL控制文件进行了详细描述并进行了恢复测试。


控制文件内容


Oracle控制文件内容


从官方文档上可以知道控制文件保存着下列信息:

  • 数据库名以及数据创建时间等

  • 相关数据文件和重做日志文件的名称和位置

  • 表空间信息

  • 重做日志线程、文件信息

  • 备份集及备份文件信息

  • 检查点及SCN信息等

  • 12c增加了PDB的信息

由于控制文件是个二进制文件,无法直接打开查阅,可以将控制文件内容转储出来便于查看,可以使用以下命令来做转存。

SQL>  alter session set events 'immediate trace name controlf level 8';
Session altered.
SQL> select value from v$diag_info where name='Default Trace File';
VALUE
--------------------------------------------------------------------------------
/u01/app/oracle/diag/rdbms/rac12201/RAC122011/trace/RAC122011_ora_24813.trc

注意,从11g开始可以通过v$diag_info获得当前会话转储文件的名称。

打开跟踪文件可以清晰的看到控制文件的内容,最开始的一段是关于数据库ID、名称等的概要信息:

Trace file /u01/app/oracle/diag/rdbms/rac12201/RAC122011/trace/RAC122011_ora_24813.trc
Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production
Build label:    RDBMS_12.2.0.1.0_LINUX.X64_170125
ORACLE_HOME:    /u01/app/oracle/product/12.2.0.1/dbhome_1
System name:    Linux
Node name:      ractest1
Release:        2.6.32-431.el6.x86_64
Version:        #1 SMP Sun Nov 10 22:19:54 EST 2013
Machine:        x86_64
Instance name: RAC122011
Redo thread mounted by this instance: 1
Oracle process number: 96
Unix process pid: 24813, image: oracle@ractest1 (TNS V1-V3)
*** 2019-05-30T09:15:38.980823+08:00 (CDB$ROOT(1))
*** SESSION ID:(59.49876) 2019-05-30T09:15:38.980878+08:00
*** CLIENT ID:() 2019-05-30T09:15:38.980885+08:00
*** SERVICE NAME:(SYS$USERS) 2019-05-30T09:15:38.980891+08:00
*** MODULE NAME:(sqlplus@ractest1 (TNS V1-V3)) 2019-05-30T09:15:38.980897+08:00
*** ACTION NAME:() 2019-05-30T09:15:38.980903+08:00
*** CLIENT DRIVER:(SQL*PLUS) 2019-05-30T09:15:38.980908+08:00
*** CONTAINER ID:(1) 2019-05-30T09:15:38.980914+08:00
DUMP OF CONTROL FILES, Seq # 233771 = 0x3912b
V10 STYLE FILE HEADER:
        Compatibility Vsn = 203424000=0xc200100
        Db ID=1217928546=0x48981d62, Db Name='RAC12201'
        Activation ID=0=0x0
        Control Seq=233771=0x3912b, File size=1216=0x4c0
        File Number=0, Blksiz=16384, File Type=1 CONTROL

接下来是数据条目的详细信息,包括了数据的名称、数据文件及日志文件的数量、数据库的检查点及SCN信息等:

***************************************************************************
DATABASE ENTRY
***************************************************************************
(size = 316, compat size = 316, section max = 1, section in-use = 1,
  last-recid= 0, old-recno = 0, last-recno = 0)
(extent = 1, blkno = 1, numrecs = 1)
03/31/2019 23:47:46
DB Name "RAC12201"
Database flags = 0x10406001 0x00001200 0x00000082
Controlfile Creation Timestamp  03/31/2019 23:47:47
Incmplt recovery scn: 0x0000000000000000
Resetlogs scn: 0x0000000000157e2e Resetlogs Timestamp  03/31/2019 23:47:49
Prior resetlogs scn: 0x0000000000000001 Prior resetlogs Timestamp  01/26/2017 13:52:29
Redo Version: compatible=0xc200100
#Data files = 28, #Online files = 25
Database checkpoint: Thread=1 scn: 0x0000000002