前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle-PFILE和SPFILE解读

Oracle-PFILE和SPFILE解读

作者头像
小小工匠
发布2021-08-16 14:50:09
8810
发布2021-08-16 14:50:09
举报
文章被收录于专栏:小工匠聊架构

概述

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实例是由那种类型的初始化参数文件启动

代码语言:javascript
复制
SQL> select decode(value, null, 'pfile', 'spfile')  from V$parameter where name = 'spfile';

DECODE(VALUE,NULL,'PFILE','SPF
------------------------------
spfile
代码语言:javascript
复制
SQL> select value from V$parameter where name = 'spfile';

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

或者

代码语言:javascript
复制
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

代码语言:javascript
复制
create spfile[='xxxxx'] from pfile[='xxxx']; 

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

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

代码语言:javascript
复制
SQL> create pfile from spfile;

File created.

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

代码语言:javascript
复制
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。

代码语言:javascript
复制
SQL> create spfile = '/opt/app/oracle/oradata/orcl/spfile.ora' from pfile;
File created.

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

通过spfile文件修改动态参数

代码语言:javascript
复制
alter system set parameter=Value scope=memory|spfile|both  

memory:只改变当前实例运行,重启数据库后失效 spfile:只改变spfile设置,不改变当前实例设置,重启数据库后生效 both:同时改变spfile和实例设置,当前更改立即生效,重启后依然有效

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


备份spfile

rman 提供了备份spfile 的功能.

代码语言:javascript
复制
RMAN> backup spfile;--显示的发出备份spfile 的命令。

开启spfile 的自动备份功能。

代码语言:javascript
复制
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 中的某个参数使用

代码语言:javascript
复制
alter system reset parameter = values...

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016/11/20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概述
  • 查看oracle实例是由那种类型的初始化参数文件启动
  • spfile 优点
  • pfile 与 spfile 的区别
  • 重建pfile 或 spfile
  • 通过spfile文件修改动态参数
  • 备份spfile
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档