微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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...

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐