oracle10g的spfile与pfile

转载 2011年01月17日 13:51:00

  1.spfile是Oracle9i之后引入的,目的是提高系统安全性。在Oracle8i下初始化参数文件为文本文件,可以使用文本编辑器进行编辑,当需要修改初始化参数时,需要在init.ora文件中修改,再重新启动数据库实例。在Oracle10g,引入了服务器参数文件(spfile),可以简化初始化参数的管理。spfile文件是一个二进制文件,不能使用文本编辑器(虽然文本编辑器打开后,能够看到参数内容),否则可能造成Oracle无法识别spfile文件。
以下以我自己系统安装的Oracle与大家讨论这二者的用法:
D盘是Oracle10g的主安装目录,分别在

(1)D:/oracle/product/10.2.0/admin/orcl/pfile/init.ora.3142010101424

(2)D:/oracle/product/10.2.0/db_1/database/initorcl.ora

(3)D:/oracle/product/10.2.0/db_1/dbs/SPFILEORCL.ORA

3个位置可以找到pfile、spfile的位置和spfile,其中(1)就是那个文本文件pfile,(2)指的是(3)的位置,(3)就是哪个二进制文件spfile,如果spfile被损坏了,那么重新启动数据库就会报找不到spfile的错误,这事需要通过pfile创建spfile:
create spfile from pfile='D:/oracle/product/10.2.0/admin/orcl/pfile/init.ora.3142010101424';
并且重新启动数据库时用startup pfile='D:/oracle/product/10.2.0/admin/orcl/pfile/init.ora.3142010101424'。
如果(2)被修改了路径,那么3的位置要做相应的调整,不然数据库重启启动会报同样的错误。
如果(1)被损坏或删除,数据库可以照常启动,但为了保险,我们还是重新创建一个新的pfile:
create pfile='D:/oracle/product/10.2.0/admin/orcl/pfile/init.ora.3142010101424' from spfile;


  2.查看系统是以pfile还是spfile 启动:
Select isspecified,count(*) from v$spparameter group by isspecified;
如果 isspecified里有true,表明用spfile进行了指定配置
如果全为false,则表明用pfile启动


  3.使用SPfile的好处:
Spfile 改正了pfile管理混乱的问题,在多结点的环境里,pfile会有多个image
启动时候需要跟踪最新的image。这是个烦琐的过程。
用spfile以后,所有参数改变都写到spfile里面(只要定义 scope=spfile或both),参数配置有个权威的来源。

 

  4.从spfile获取pfile
Create pfile='d:pfileSID.ora' from spfile;
Create pfile='d:pfileSID.ora' from spfile='spfile_location';

 

  5.从pfile获取spfile
Create spfile from pfile='Your_pfile_location'
Create spfile='spfile_location' from pfile='Your_pfile_location'
 
  6.动态修改参数
 alter system set parameter=Value scope=spfile|both|memory
 
  7.Startup nomount的时候需要读去spfile或pfile,两者共存,spfile优先

 

  8.试验心得:

 环境:window2003  Oracle10g

 问题描述:一个数据库实例,包含二个数据库(test,orcl),因为设置错误的参数造成orcl数据库spfile文件损坏。通过create spfile生成文件后,一次一只能启动一个数据库。

解决过程:


C:/Documents and Settings/hsx>set oracle_sid=orcl

C:/Documents and Settings/hsx>sqlplus/nolog

SQL*Plus: Release 10.2.0.1.0 - Production on 星期六 5月 15 17:37:34 2010

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

SQL> conn sys/sys as sysdba
已连接到空闲例程。
SQL> create spfile from pfile='D:/oracle/product/10.2.0/admin/orcl/pfile/init.or
a.3142010101424';

文件已创建。

SQL> startup pfile='D:/oracle/product/10.2.0/admin/orcl/pfile/init.ora.314201010
1424'
ORACLE 例程已经启动。

Total System Global Area  612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             167775108 bytes
Database Buffers          436207616 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
数据库已经打开。
SQL> shutdown immediate
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup
ORACLE 例程已经启动。

Total System Global Area  612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             184552324 bytes
Database Buffers          419430400 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
数据库已经打开。
SQL> Select isspecified,count(*) from v$spparameter group by isspecified;

ISSPEC   COUNT(*)
------ ----------
TRUE           23
FALSE         236


备注:假如有多个数据库的话,可以通过设置set oracle_sid, 然后pfile单独启动

Oracle10g的spfile与pfile

从oracle 9i开始,oracle缺省使用spfile启动数据库,spfile必须由pfile创建,新建的spfile将在下一次启动数据库时生效。 pfile为初始化参数文件(Initializ...

Oracle10g-pfile文件参数详解.pdf

  • 2012年01月06日 20:20
  • 195KB
  • 下载

[oracle10g]初始化参数文件pfile中各参数的含义

根据上一篇博客,pfile中存放着数据库的一部分初始化参数,这里根据我获得的pfile(windows下oracle10g企业版)总结一下各个参数的含义: orcl.__db_cache_size=3...
  • joyeu
  • joyeu
  • 2013年08月27日 15:47
  • 1319

在oracle10g上创建spfile.doc

  • 2009年04月22日 17:33
  • 24KB
  • 下载

oracle的pfile与spfile

pfile(Initialization Parameter File)用于Oracle8i,在oracle9i中也可以用,以文本形式存在,可以用文本编辑器对其中参数进行修改。   spfile(S...

oracle 参数文件 pfile/spfile ---详解

oracle有三种状态: (1)nomount (2)mount (3)open 在数据库启动的时候,首先读取的是参数文件,然后是控制文件最后在挂载打开数据库文件。 我们首先了解一下什么是参...

ORACLE spfile and pfile

SQL> create spfile=D:/oracle/product/10.1.0/db_1/dbs/SPFILEORCL.ORA from pfile=c:/oracle.ora  2  ;文件...

Oracle Spfile 與Pfile..

1、pfile 文本文件 client端參數文件;不能動態修改,可以用普通的編輯器修改,修改之後需要重啟。pfile可能會導致服務器啟動不一致,因為可以在客戶端啟動。 2、spfile 二進制文件 ...

Oracle初始化参数文件spfile 和 pfile

实例启动时Oracle将读入初始化参数文件的每个参数项 ,参数文件有两种类型的参数1)显示:在该文件中有一个参数项。2)隐式:在该文件中没有参数项,但使用Oracle的默认值...

判断ORACLE启动时使用spfile还是pfile

判断ORACLE启动时使用spfile还是pfile    自Oracle 9i以后启动的时候默认使用的初始化文件是spfile,我们可以通过如下三种方式来判断是SPFILE还是PFILE方式启...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle10g的spfile与pfile
举报原因:
原因补充:

(最多只允许输入30个字)