概述

oracle中的参数文件是一个包含一系列参数以及参数对应的值的系统文件,它可以分为两种类型:pfile和spfile。他们是在数据库实例启动时加载的,决定了数据库的物理结构,内存,数据库的限制及系统大量的默认值,数据库的各种物理属性,指定数据控制文件名(当数据库实例由nomount启动到mount状态时,就会通过参数文件找到对应的控制文件,来装载对应的数据库)和路径等信息,是进行数据库设计和性能调优的重要文件。

oracledump文件解析,详解oracle参数文件PFILE和SPFILE(1)


PFILE概念

Pfile(Parameter File,参数文件)是基于文本格式的参数文件,含有数据库的配置参数。

1、PFILE - initSID.ora(默认PFILE名称)

位置在$ORACLE_HOME/dbs目录下面。这是一个文本文件,可以用任何文本编辑工具打开。

2、创建PFILE

cp init.ora $ORACLE_HOME/dbs/initorcl.ora

编辑initorcl.ora文件,修改适合自己的参数。建议不要使用oracle提供的初始化参数

需要修改的名字有:

db_name=orcl

#添加db_block_size

db_block_size=8192

control_files=('目录/control01.ctl','目录/control02.ctl', '目录/control03.ctl')

3、修改参数

alter system set parameter=Value scope=memory;

MEMORY:只改变当前实例运行;

以pfile启动的数据库修改参数后并不会写入pfile文件,用pfiile或spfile重启数据库参数会变成默认值。


SPFILE概念: Oracle9i之后引入的概念

SPfile(Server Parameter File,服务器参数文件)是基于二进制格式的参数文件,含有数据库及例程的参数和数值,但不能用文本编辑工具打开。

1、动态修改参数

alter system set parameter=Value scope={spfile|both|memory};

SCOPE参数有三个可选值:

MEMORY:只改变当前实例运行;

SPFILE:只改变SPFILE的设置(如果修改的是静态参数,则必须指定SCOPE=SPFILE,否则将会报ORA-02095错);

BOTH:改变实例及SPFILE(使用BOTH选项实际上等同于不带参数的ALTER SYSTEM语句)。

2、创建spfile

SPFILE->spfileSID.ora,位置在$ORACLE_HOME/dbs目录下面

根据PFILE创建SPFILE, 在启动Instance实例之前或之后都可以创建SPFILE。

CREATE SPFILE = ‘$ORACLE_HOME/dbs/spfileDBA01.ora’ FROM PFILE = ‘$ORACLE_HOME/dbs/initDBA01.ora;

也可以使用缺省的方式来创建SPFILE

create spfile from pfile;

3、查看SPFILE等二进制文件使用

strings spfilewilson.ora

4、修改SPFILE的内容:

alter system set parameter=value <comment='text'> <deferred> <scope=memory|spfile|both><sid='sid|*'>

其中deferred表示延迟生效,可以通过show parameter fast_start_查看fast_start_开头的所有参数是否已经生效。


spfile和pfile互相转换

从spfile获取pfile

Create pfile='/tmp/pfile' from spfile;

create pfile='/tmp/pfile' from spfile='spfile_location';

从pfile获取spfile

Create spfile from pfile='Your_pfile_location'

Create spfile='spfile_location' from pfile='Your_pfile_location'

Startup nomount的时候需要读去spfile或pfile,两者共存,spfile优先

强制用pfile启动

SQL>startup nomount pfile='/tmp/pfile'


关于pfile和spfile就介绍到这了,后面会分享更多关于DBA内容,感兴趣的朋友可以关注下~

oracledump文件解析,详解oracle参数文件PFILE和SPFILE(2)

,