这篇文章给大家分享的是有关在Oracle实例关闭时怎样修改spfile的参数的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

具体的操作如下:

一、查询sga大小

SQL>showparametersgaNAMETYPEVALUE-----------------------------------------------------------------------------lock_sgabooleanFALSEpre_page_sgabooleanFALSEsga_max_sizebiginteger1Gsga_targetbiginteger1G

二、修改sga大小为500M

SQL>altersystemsetsga_target=500Mscope=spfile;Systemaltered.

三、因为是指定参数为spfile,因此要重启instance才能使参数生效

SQL>shutdownimmediate;Databaseclosed.Databasedismounted.ORACLEinstanceshutdown.

四、重启instance 时,提示sga最小值应该为668M

SQL>startupORA-01078:failureinprocessingsystemparametersORA-00821:Specifiedvalueofsga_target500Mistoosmall,needstobeatleast668M

解决细路:

首先我们要理解一下oracle数据库在启动过程中调用 的参数,其顺序为:

spfilesid.ora -> spfile.ora ->initsid.ora-> init.ora 从这条启动线来说,如果第一个spfilesid.ora文件找不到的话,它会找到二个spfile.ora文件,如果能找到就能正常启动,若找不到,再继续找下一个initsid.ora文件,一直找到最后一个init.ora文件,说明:如果找到其中一个则会正常启动instance

解决方法:

通过创建pfile文件方式来启动数据库,然后再以pfile文件为模板创建spfile,具体步骤是:

1、以spfile模板创建pfile文件,并指定路径为本地硬盘位置

createpfile='/oracle/initudevasm.ora'fromspfile='+DGDATA02/udevasm/spfileudevasm.ora';

2、修改initudevasm.ora文件,找到sga_target字段,修改大于 668M

vi/oracle/initudevasm.oraudevasm.__db_cache_size=826277888udevasm.__java_pool_size=4194304udevasm.__large_pool_size=8388608udevasm.__oracle_base='/oracle/app/oracle'#ORACLE_BASEsetfromenvironmentudevasm.__pga_aggregate_target=629145600udevasm.__sga_target=1073741824udevasm.__shared_io_pool_size=0udevasm.__shared_pool_size=222298112udevasm.__streams_pool_size=0*.audit_file_dest='/oracle/app/oracle/admin/udevasm/adump'*.audit_trail='db'*.compatible='11.2.0.4.0'*.control_files='+DGDATA02/udevasm/controlfile/current.256.945212019'*.db_block_size=8192*.db_create_file_dest='+DGDATA02'*.db_domain=''*.db_name='udevasm'*.db_recovery_file_dest_size=3221225472*.diagnostic_dest='/oracle/app/oracle'*.dispatchers='(PROTOCOL=TCP)(SERVICE=udevasmXDB)'udevasm.log_archive_dest_1='LOCATION=+DGRECOVERY/'*.nls_language='AMERICAN'*.nls_territory='AMERICA'*.open_cursors=300*.pga_aggregate_target=629145600*.processes=1000*.remote_login_passwordfile='EXCLUSIVE'*.sessions=170*.sga_target=754288000--大于668M*.undo_tablespace='UNDOTBS1'

3、以pfile文件启动instance

SQL>startuppfile='/oracle/initudevasm.ora'ORACLEinstancestarted.TotalSystemGlobalArea751595520bytesFixedSize2257032bytesVariableSize603983736bytesDatabaseBuffers142606336bytesRedoBuffers2748416bytesDatabasemounted.Databaseopened.

4、以pfile文件为模板创建spfile文件

SQL>createspfile='+DGDATA02/udevasm/spfileudevasm.ora'frompfile='/oracle/initudevasm.ora';Filecreated.

5、关闭实例,并重新启动spfile,因为在在创建spfile时已经默认指定原来的路径,并把原来的spfile文件覆盖了,所以只要直接启动即可

SQL>shutdownimmediate;Databaseclosed.Databasedismounted.ORACLEinstanceshutdown.SQL>startupORACLEinstancestarted.TotalSystemGlobalArea751595520bytesFixedSize2257032bytesVariableSize603983736bytesDatabaseBuffers142606336bytesRedoBuffers2748416bytesDatabasemounted.Databaseopened.

6、查询修改后的sga大小

SQL>showparametersgaNAMETYPEVALUE-----------------------------------------------------------------------------lock_sgabooleanFALSEpre_page_sgabooleanFALSEsga_max_sizebiginteger720Msga_targetbiginteger720M

通过上面查询则判断已经修改恢复成功

总结:

1、当数据库发生因为有关参数文件异常无法启动正常时,可以先把原理理解,然后通过创建pfile与spfile文件方式解决启动问题。
2、要备份有关数据库参数文件以防止误操作导致数据库无法正常启动

感谢各位的阅读!关于“在Oracle实例关闭时怎样修改spfile的参数”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!