查看: 240|回复: 0

[Oracle数据库] 在Oracle实例关闭时如何修改spfile的参数详解

发表于 7 天前
尚学堂AD

问题描述:

最近在工作遇到一个问题,在Oracle 11G单机ASM中修改sga大小,修改完后,关闭instance并startup时,提示sga没有达到最小值,因些无法启动,而此时数据库实例已经关闭,已不能在之前的那种模式修改参数,下面来一起看看详细的介绍。

具体的操作如下:

一、查询sga大小

  1. SQL> show parameter sga
  2. NAME TYPE VALUE
  3. ------------------------------------ ----------- ------------------------------
  4. lock_sga boolean FALSE
  5. pre_page_sga boolean FALSE
  6. sga_max_size big integer 1G
  7. sga_target big integer 1G
复制代码

二、修改sga大小为500M

  1. SQL> alter system set sga_target=500M scope=spfile;
  2. System altered.
复制代码

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

  1. SQL> shutdown immediate;
  2. Database closed.
  3. Database dismounted.
  4. ORACLE instance shut down.
复制代码

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

  1. SQL> startup
  2. ORA-01078: failure in processing system parameters
  3. ORA-00821: Specified value of sga_target 500M is too small, needs to be at least 668M
复制代码

解决细路:

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

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

解决方法:

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

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

  1. create pfile='/oracle/initudevasm.ora' from spfile='+DGDATA02/udevasm/spfileudevasm.ora';
复制代码

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

  1. vi /oracle/initudevasm.ora
  2. udevasm.__db_cache_size=826277888
  3. udevasm.__java_pool_size=4194304
  4. udevasm.__large_pool_size=8388608
  5. udevasm.__oracle_base='/oracle/app/oracle'#ORACLE_BASE set from environment
  6. udevasm.__pga_aggregate_target=629145600
  7. udevasm.__sga_target=1073741824
  8. udevasm.__shared_io_pool_size=0
  9. udevasm.__shared_pool_size=222298112
  10. udevasm.__streams_pool_size=0
  11. *.audit_file_dest='/oracle/app/oracle/admin/udevasm/adump'
  12. *.audit_trail='db'
  13. *.compatible='11.2.0.4.0'
  14. *.control_files='+DGDATA02/udevasm/controlfile/current.256.945212019'
  15. *.db_block_size=8192
  16. *.db_create_file_dest='+DGDATA02'
  17. *.db_domain=''
  18. *.db_name='udevasm'
  19. *.db_recovery_file_dest_size=3221225472
  20. *.diagnostic_dest='/oracle/app/oracle'
  21. *.dispatchers='(PROTOCOL=TCP) (SERVICE=udevasmXDB)'
  22. udevasm.log_archive_dest_1='LOCATION=+DGRECOVERY/'
  23. *.nls_language='AMERICAN'
  24. *.nls_territory='AMERICA'
  25. *.open_cursors=300
  26. *.pga_aggregate_target=629145600
  27. *.processes=1000
  28. *.remote_login_passwordfile='EXCLUSIVE'
  29. *.sessions=170
  30. *.sga_target= 754288000 --大于668M
  31. *.undo_tablespace='UNDOTBS1'
复制代码

3、以pfile文件启动instance

  1. SQL> startup pfile= '/oracle/initudevasm.ora'
  2. ORACLE instance started.
  3. Total System Global Area 751595520 bytes
  4. Fixed Size 2257032 bytes
  5. Variable Size 603983736 bytes
  6. Database Buffers 142606336 bytes
  7. Redo Buffers 2748416 bytes
  8. Database mounted.
  9. Database opened.
复制代码

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

  1. SQL> create spfile= '+DGDATA02/udevasm/spfileudevasm.ora' from pfile= '/oracle/initudevasm.ora' ;
  2. File created.
复制代码

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

  1. SQL> shutdown immediate;
  2. Database closed.
  3. Database dismounted.
  4. ORACLE instance shut down.
  5. SQL> startup
  6. ORACLE instance started.
  7. Total System Global Area 751595520 bytes
  8. Fixed Size 2257032 bytes
  9. Variable Size 603983736 bytes
  10. Database Buffers 142606336 bytes
  11. Redo Buffers 2748416 bytes
  12. Database mounted.
  13. Database opened.
复制代码

6、查询修改后的sga大小

  1. SQL> show parameter sga
  2. NAME TYPE VALUE
  3. ------------------------------------ ----------- ------------------------------
  4. lock_sga boolean FALSE
  5. pre_page_sga boolean FALSE
  6. sga_max_size big integer 720M
  7. sga_target big integer 720M
复制代码

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

总结:

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

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对程序员之家的支持。



回复

使用道具 举报