关于Execute to Parse %:比例太低的优化思路
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,AWR报告中Execute to Parse %:比例太低,如下所示: Instance Efficiency Percentages (Target 100%)Buffer Nowait %:97.
千家信息网最后更新 2025年01月19日关于Execute to Parse %:比例太低的优化思路AWR报告中Execute to Parse %:比例太低,如下所示: Instance Efficiency Percentages (Target 100%)
Execute to Parse % 表示SQL语句解析后被重复执行命中率 计算公式=100*(1-Parses/Executions) 如果该值偏小,说明分析(硬解析与软解析 )的比例较大,快速解析(即软软解析)较少。 关于session_cached_cursors参数的调整: open_cursors:该参数含义是同一个session同时打开最多在使用的游标数。在Oracle10.2.0.1.0版本中默认为300。 session_cached_cursors:SESSION_CACHED_CURSORS, 就是说的是一个session可以缓存多少个cursor,让后续相同的SQL语句不再打开游标,从而避免软解析的过程来提高性能。(绑定变量是解决硬解析的问题),软解析同硬解析一样,同样消耗资源.所以这个参数非常重要。在Oracle10.2.0.1.0版本中默认为20。 现在需要改大这个参数,以便于进行更多的软软解析,这样可以省去open一个新的 session cursor和close一个现有session cursor所需要消耗的资源和时间。 通过下面语句查看验证了session_cached_cursors 的使用率确实为100%,(这是我当时查看验证的) SQL> Select 'session_cached_cursors' Parameter, Lpad(Value, 5) Value, Decode(Value, 0, ' n/a', To_Char(100 * Used / Value, '990') || '%') Usage From (Select Max(s.Value) Used From V$statname n, V$sesstat s Where n.Name = 'session cursor cache count' And s.Statistic# = n.Statistic#), (Select Value From V$parameter Where Name = 'session_cached_cursors') Union All Select 'open_cursors', Lpad(Value, 5), To_Char(100 * Used / Value, '990') || '%' From (Select Max(Sum(s.Value)) Used From V$statname n, V$sesstat s Where n.Name In ('opened cursors current', 'session cursor cache count') And s.Statistic# = n.Statistic# Group By s.Sid), (Select Value From V$parameter Where Name = 'open_cursors'); PARAMETER VALUE USAGE ---------------------- ---------- ----- session_cached_cursors 50 100% open_cursors 300 22% 再次验证session_cached_cursors是否合理: session_cached_cursors的值也不是越大越好,我们可以通过下面两条语句进一步验证该参数是否合理: SQL> SELECT NAME, VALUE FROM V$SYSSTAT WHERE NAME LIKE '%cursor%'; NAME VALUE ---------------------------------------------------------------- ---------- opened cursors cumulative 1075158364 opened cursors current 1578 pinned cursors current 458 session cursor cache hits 140287938 session cursor cache count 20425458 cursor authentications 18472351 SQL> SELECT NAME, VALUE FROM V$SYSSTAT WHERE NAME LIKE '%parse%'; NAME VALUE ---------------------------------------------------------------- ---------- ADG parselock X get attempts 0 ADG parselock X get successes 0 parse time cpu 13211356 parse time elapsed 19331036 parse count (total) 1020611015 parse count (hard) 83024992 parse count (failures) 504137 parse count (describe) 20927 Session cursor cache hits就是系统在高速缓存区中找到相应cursors的次数,parse count(total)就是总的解析次数,二者比值越高,性能越好。如果比例比较低,并且有较多剩余内存的话,可以考虑加大该参数。如下所示二者的比例比较低, SQL> select 140289159/1020611015*100 from dual; 140289159/1020611015*100 ------------------------ 13.745605 通过下面的语句来判断open_cursors的大小是否合理,如下所示,我的是合理的。 SQL>SELECT MAX(A.VALUE) AS HIGHEST_OPEN_CUR, P.VALUE AS MAX_OPEN_CUR FROM V$SESSTAT A, V$STATNAME B, V$PARAMETER P WHERE A.STATISTIC# = B.STATISTIC# AND B.NAME = 'opened cursors current' AND P.NAME = 'open_cursors' GROUP BY P.VALUE; HIGHEST_OPEN_CUR MAX_OPEN_CUR -------------------------------------------------------------------------------- 34 300
综上所述可以确定需要加大参数session_cached_cursors来提高oracle数据库的性能,但是参数session_cached_cursors并不是越大越好,太大会引起pga缓存碎片,消耗内存,然后session cursor cache的管理也是使用LRU。
Buffer Nowait %: | 97.33 | Redo NoWait %: | 100.00 |
Buffer Hit %: | 96.59 | In-memory Sort %: | 100.00 |
Library Hit %: | 84.65 | Soft Parse %: | 93.10 |
Execute to Parse %: | 2.60 | Latch Hit %: | 99.32 |
Parse CPU to Parse Elapsd %: | 75.73 | % Non-Parse CPU: | 99.03 |
综上所述可以确定需要加大参数session_cached_cursors来提高oracle数据库的性能,但是参数session_cached_cursors并不是越大越好,太大会引起pga缓存碎片,消耗内存,然后session cursor cache的管理也是使用LRU。
参数
语句
比例
验证
就是
性能
越好
消耗
内存
次数
游标
版本
缓存
资源
相同
较大
重要
使用率
公式
再次
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
苏州网络安全防护网
旅游景点信息管理数据库
sql2012导入数据库
2021网络安全排行榜
网络安全明白人
数据库表删除索引
云服务器1m宽带
力控7.1关系数据库操作
软件开发一线和二线
数据库安全设置与保护实验
软件开发怎么打入市场
招聘软件开发人员有哪些要求
gdc服务器怎么清除冗余
wsn网络安全
城厢雅绅网络技术是什么
连云港企业软件开发管理方法
华为h22m-03服务器说明书
网络安全保险内容
服务器身份认证和客户端身份认证
用vga配置服务器
数据库设置银行卡固定开头
mes系统的软件开发
服务器网络共享盘
对于网络安全的认知
浅谈计算机数据库技术的应用
浙江代还软件开发
网络安全时代来临意味什么
gdc服务器怎么清除冗余
黄岛丰田卡罗拉销售服务器
长春软件开发优先吉网传媒好