oracle重建spfile,在Oracle实例关闭情况下如何修改spfile的参数

重要说明:由于本文由本人测试并完成,其中可能还有不足之处,另外不同的环境可能也有不同的解决方法,本文仅供参考,并欢迎指证

问题描述:

在11G单机ASM中修改sga大小,修改完后,关闭instance并startup时,提示sga没有达到最小值,因些无法启动,而此时数据库实例已经关闭,已不能在之前的那种模式修改参数,具体的操作如下:

1、查询sga大小

sql>showparametersga

NAMETYPEVALUE

-----------------------------------------------------------------------------

lock_sgabooleanFALSE

pre_page_sgabooleanFALSE

sga_max_sizebiginteger1G

sga_targetbiginteger1G

2、修改sga大小为500M

sql>altersystemsetsga_target=500Mscope=spfile;

Systemaltered.

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

sql>shutdownimmediate;

Databaseclosed.

Databasedismounted.

ORACLEinstanceshutdown.

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

sql>startup

ORA-01078:failureinprocessingsystemparameters

ORA-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文件,并指定路径为本地硬盘位置

create pfile='/oracle/initudevasm.ora' from spfile='+DGDATA02/udevasm/spfileudevasm.ora';

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

vi /oracle/initudevasm.ora

udevasm.__db_cache_size=826277888

udevasm.__java_pool_size=4194304

udevasm.__large_pool_size=8388608

udevasm.__oracle_base='/oracle/app/oracle'#ORACLE_BASE set from environment

udevasm.__pga_aggregate_target=629145600

udevasm.__sga_target=1073741824

udevasm.__shared_io_pool_size=0

udevasm.__shared_pool_size=222298112

udevasm.__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.

TotalSystemGlobalArea751595520bytes

FixedSize2257032bytes

VariableSize603983736bytes

DatabaseBuffers142606336bytes

RedoBuffers2748416bytes

Databasemounted.

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>startup

ORACLEinstancestarted.

TotalSystemGlobalArea751595520bytes

FixedSize2257032bytes

VariableSize603983736bytes

DatabaseBuffers142606336bytes

RedoBuffers2748416bytes

Databasemounted.

DatabaSEOpened.

6、查询修改后的sga大小

sql>showparametersga

NAMETYPEVALUE

-----------------------------------------------------------------------------

lock_sgabooleanFALSE

pre_page_sgabooleanFALSE

sga_max_sizebiginteger720M

sga_targetbiginteger720M

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

总结:

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

2、要备份有关数据库参数文件以防止误操作导致数据库无法正常启动

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值