在Oracle实例关闭时如何修改spfile的参数详解
发布时间 - 2026-01-11 02:19:06 点击率:次问题描述:

最近在工作遇到一个问题,在Oracle 11G单机ASM中修改sga大小,修改完后,关闭instance并startup时,提示sga没有达到最小值,因些无法启动,而此时数据库实例已经关闭,已不能在之前的那种模式修改参数,下面来一起看看详细的介绍。
具体的操作如下:
一、查询sga大小
SQL> show parameter sga NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ lock_sga boolean FALSE pre_page_sga boolean FALSE sga_max_size big integer 1G sga_target big integer 1G
二、修改sga大小为500M
SQL> alter system set sga_target=500M scope=spfile; System altered.
三、因为是指定参数为spfile,因此要重启instance才能使参数生效
SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down.
四、重启instance 时,提示sga最小值应该为668M
SQL> startup ORA-01078: failure in processing system parameters 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文件,并指定路径为本地硬盘位置
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> startup pfile= '/oracle/initudevasm.ora' ORACLE instance started. Total System Global Area 751595520 bytes Fixed Size 2257032 bytes Variable Size 603983736 bytes Database Buffers 142606336 bytes Redo Buffers 2748416 bytes Database mounted. Database opened.
4、以pfile文件为模板创建spfile文件
SQL> create spfile= '+DGDATA02/udevasm/spfileudevasm.ora' from pfile= '/oracle/initudevasm.ora' ; File created.
5、关闭实例,并重新启动spfile,因为在在创建spfile时已经默认指定原来的路径,并把原来的spfile文件覆盖了,所以只要直接启动即可
SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup ORACLE instance started. Total System Global Area 751595520 bytes Fixed Size 2257032 bytes Variable Size 603983736 bytes Database Buffers 142606336 bytes Redo Buffers 2748416 bytes Database mounted. Database opened.
6、查询修改后的sga大小
SQL> show parameter sga NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ lock_sga boolean FALSE pre_page_sga boolean FALSE sga_max_size big integer 720M sga_target big integer 720M
通过上面查询则判断已经修改恢复成功
总结:
1、当数据库发生因为有关参数文件异常无法启动正常时,可以先把原理理解,然后通过创建pfile与spfile文件方式解决启动问题。
2、要备份有关数据库参数文件以防止误操作导致数据库无法正常启动
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# oracle
# 关闭实例
# spfile
# 修改spfile
# 在Oracle关闭情况下如何修改spfile的参数
# 找不到
# 重启
# 无法启动
# 最小值
# 好了
# 第一个
# 就能
# 能在
# 这条
# 一个问题
# 能找到
# 这篇文章
# 其中一个
# 能使
# 谢谢大家
# 先把
# 它会
# 二个
# 重新启动
# 并把
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
如何在云虚拟主机上快速搭建个人网站?
JavaScript如何实现音频处理_Web Audio API如何工作?
如何快速完成中国万网建站详细流程?
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
简单实现Android文件上传
Laravel如何实现全文搜索功能?(Scout和Algolia示例)
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程
实例解析angularjs的filter过滤器
如何彻底删除建站之星生成的Banner?
Python文件流缓冲机制_IO性能解析【教程】
Laravel API资源类怎么用_Laravel API Resource数据转换
如何在IIS中新建站点并配置端口与IP地址?
济南网站建设制作公司,室内设计网站一般都有哪些功能?
如何选择可靠的免备案建站服务器?
Laravel怎么导出Excel文件_Laravel Excel插件使用教程
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
用v-html解决Vue.js渲染中html标签不被解析的问题
教你用AI将一段旋律扩展成一首完整的曲子
php静态变量怎么调试_php静态变量作用域调试技巧【解答】
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
利用JavaScript实现拖拽改变元素大小
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
Laravel如何记录自定义日志?(Log频道配置)
Laravel Session怎么存储_Laravel Session驱动配置详解
Python正则表达式进阶教程_复杂匹配与分组替换解析
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
如何快速生成ASP一键建站模板并优化安全性?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
微信小程序 input输入框控件详解及实例(多种示例)
Linux安全能力提升路径_长期防护思维说明【指导】
MySQL查询结果复制到新表的方法(更新、插入)
高防服务器租用首荐平台,企业级优惠套餐快速部署
Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)
如何挑选优质建站一级代理提升网站排名?
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
网站页面设计需要考虑到这些问题
Laravel如何使用Sanctum进行API认证?(SPA实战)
制作公司内部网站有哪些,内网如何建网站?
Laravel如何使用Telescope进行调试?(安装和使用教程)
Laravel如何使用Gate和Policy进行授权?(权限控制)
Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】
Python文件操作最佳实践_稳定性说明【指导】
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
电商网站制作价格怎么算,网上拍卖流程以及规则?

