Oracle-pfile和spfile解读

概述

ORACLE中的参数文件一个包含一系列参数以及参数对应值的操作系统文件,可以分为两种类型。它们是在数据库实例启动时候加载的,决定了数据库的物理结构、内存、数据库的限制及系统大量的认值、数据库的各种物理属性、指定数据库控制文件名和路径等信息,是进行数据库设计和性能调优的重要文件

初始化参数文件(Initialization Parameters Files),Oracle 9i之前,ORACLE一直采用PFILE方式存储初始化参数,该文件为文本文件

服务器参数文件(Server Parameter Files),从Oracle 9i开始,Oracle引入了SPFILE文件,该文件为二进制格式,不能通过手工修改
只能通过alter system set 命名动态的修改初始化参数的值,如果手动的修改spfile 将会导致文件损坏,实例不能启动。

从Oracle 9i开始,Oracle缺省使用spfile启动数据库,spfile必须由pfile创建,新建的spfile将在下一次启动数据库时生效。

查看oracle实例是由那种类型的初始化参数文件启动

sql> select decode(value,null,'pfile','spfile')  from V$parameter where name = 'spfile';

DECODE(VALUE,NULL,'PFILE','SPF ------------------------------
spfile
sql> select value from V$parameter where name = 'spfile';

VALUE ------------------------------------------------------------
/oracle/product/112/dbs/spfilecc.ora

或者

sql>  show parameter pfile

NAME          TYPE        VALUE
-------- ------ ------------
spfile    string      /oracle/product/112/dbs/spfilecc.ora

++++++++++++++++++++++++++++++++++++++++++++++

sql> show parameter spfile

NAME          TYPE        VALUE
-------- ------ ------------
spfile    string      /oracle/product/112/dbs/spfilecc.ora

如果数据库使用spfile参数文件,那么用show parameter spfile与 show parameter pfile的结果一致,如果数据库使用pfile参数文件,那么上面命令得到的结果都是空.

spfile 优点

  • 1、可以使用rman 来备份spfile,rman 不支持备份pfile。

  • 2、减少人为错误,spfile 是由oracle 数据库维护的,在对其中的参数做修改的时候oracle 数据库会做检查。

  • 3、使用方便,如果你想远程启动数据库,不像pfile 需要本地的初始化参数文件副本。

  • 4、查找定位方便。

pfile 与 spfile 的区别

  • 1、pfile 是静态的如果需要修改可以使用vi 等文字编辑工具手动修改。如果需要远程启动数据库,需要pfile 的本地副本。

  • 2、spfile 可以通过alter system set 命名动态的修改初始化参数的值,如果手动的修改spfile 将会导致文件损坏,实例不能启动。

重建pfile 或 spfile

create spfile[='xxxxx'] from pfile[='xxxx']; 

create pfile[='xxxxx'] from spfile[='xxxx'];

通过spfile创建pfile文件(此时会在$ORACLE_HOME/dbs目录下生成pfile.当然你也可以指定参数文件的位置。

sql> create pfile from spfile;

File created.

如果当前实例是使用spfile 启动的那么是不可以使用下面的命令来创建spfile 的。

sql> create spfile from pfile;
create spfile from pfile
*
ERROR at line 1:
ORA-32002: cannot create SPFILE already being used by the instance

但你可以使用指定不同于认路径的方式来创建spfile。

sql> create spfile = '/opt/app/oracle/oradata/orcl/spfile.ora' from pfile;
File created.

如果在pfile 和 spfile 的相互转化过程中需要的话pfile 也是可以指定路径的。
create pfile 与create spfile 只要实例启动以后就可以执行。

通过spfile文件修改动态参数

alter system set parameter=Value scope=memory|spfile|both 

memory:只改变当前实例运行,重启数据库后失效

spfile:只改变spfile设置,不改变当前实例设置,重启数据库后生效

both:同时改变spfile和实例设置,当前更改立即生效,重启后依然有效

当没有指定scope 的时候,如果实例是使用pfile 启动的那么认的scope 方式是memory。如果实例是使用spfile 启动的认的scope 方式是both。

备份spfile

rman 提供了备份spfile 的功能.

RMAN> backup spfile;--显示的发出备份spfile 的命令。

开启spfile 的自动备份功能

RMAN> CONfigURE CONTROLFILE AUTOBACKUP ON;
new RMAN configuration parameters:
CONfigURE CONTROLFILE AUTOBACKUP ON;
new RMAN configuration parameters are successfully stored

设置了上述参数以后rman 在执行backup 命令的时候会自动的备份控制文件和参数文件(前提是实例是使用spfile启动的)。
注:初始化参数文件中至少要包含一个参数:DB_NAME 该参数是没有认值的。如果要删除spfiel 中的某个参数使用

alter system reset parameter = values...

删除的参数在下次实例运行期间生效。

相关文章

Java Oracle 结果集是Java语言中处理数据库查询结果的一种方...
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密...
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台...
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的...
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常...
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上...