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