重庆oracle认证培训机构

新闻分类

产品分类

热门关键词

联系我们

企业名称:重庆赛烽达科技有限公司

联系人:程老师

手机:13372708242

邮箱:xqzhang@saifengda.com

网址:www.cqora.com

地址:重庆石桥铺高创锦业17-3

Oracle技巧:ORA-4030 报错

您的当前位置: 首 页 >> 新闻资讯 >> 行业新闻

Oracle技巧:ORA-4030 报错

发布日期:2019-08-28 作者: 点击:

  这个错误原因是 Oracle 服务器进程不能从操作系统上分配出更多内存。含有PGA(程序全局区)的进程其内存的分配取决于服务器的设置。对于 dedicated 服务器进程,其包含了 stack 堆栈和 UGA(用户全局区), 保存有用户会话信息、游标信息和数据分类排序区。在多线程模式配置(shared 服务器)中,UGA 是在 SGA 中进行分配,所以不对 ORA-4030 报错负责。


  因此 ORA-4030 是对需要更多内存(用于 stack UGA 或 PGA)来完成工作的进程而言的。


  请记住产生 ORA-4030 错误的进程并非总是内存损耗的元凶, 错误的发生仅仅是因为此进程无法取得所需的内存造成的。


  当你碰到这个错误时,意味着你已不能从系统中分配内存。这可能是由于你的进程本身导致的(如果你的进程正需求很多内存),也可能是其他原因导致操作系统内存被耗尽 (如过大的 SGA 或者太多进程占用了系统的物理内存和虚拟内存) 。


  如何处理此问题?


  1. 确定是否还有足够可用内存?使用系统专用工具来检查内存使用情况 (如vmstat, top 等)。


  2. 是否存在操作系统设定限制? 检查 ulimit 命令检查当前资源限制。


  3. 是否存在 Oracle 限制设置? 检查 pga_aggregate_target 和相关会话的 pga 内存值。


  4. 找出当前哪个进程正在要求大量内存, 可通过 v$statname 和 v$sesstat 以了解当前最忙的进程。


  当进程正在稳定增长其所需内存时,我们可以观察它们的运行:


  - 通过 v$sql_area 可以看到哪些命令正被执行:


  SQL> select sql_text from v$sqlarea a, v$session s where a.address= s.sql_address and s.sid = <SID>;


  - 你也可以通过 heapdump 转储来查看它们:


  SQL> oradebug setorapid 10 (10 是 Oracle 进程 Id, 使用 setospid 以设置当前调试进程)


  SQL> oradebug unlimit


  SQL> oradebug dump heapdump 5


  - 如果报错问题间歇性发生或者由于进程失败太快以至于难以捕获 (但又很可能是内存大量消耗的根本原因),则我们可以设置事件来获取 heapdump 转储信息:


  SQL> alter sssion set events '4030 trace name heapdump level 5';


  …或者直接在 init.ora 文件中设置 event.


本文网址:http://www.cqora.com/news/637.html

关键词:重庆oracle培训

最近浏览:

报名咨询

点击咨询报名

赛烽达QQ群

赛烽达技术群

程老师

xxxxxxxxxx

加微信咨询

张老师微信.jpg

xqzhang@saifengda.com