在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 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、要备份有关数据库参数文件以防止误操作导致数据库无法正常启动 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- C#获取指定目录最后写入时间的方法
- Flash Builder 4.6 无法生成 html 文件的解决方法
- dojo -- it is critical to pull in "dojo/domReady!&a
- 将字符串s倒置的各种方法:说什么微软面试题,其实在K&R书
- DDD调试opencore/stagefright(转载更新版)
- ruby-on-rails – Ruby on Rails,rake db:seed或db:reset
- AJAX入门
- ruby-on-rails – 使用RSPEC进行测试时突然出现无法解释的活
- 绑定数据中 DataGridView的表头的制作
- 如何使用Swift中带有typealias的Protocol中的约束引用泛型类