资深Oracle数据库专家 OCM认证大师 10年数据库相关服务及开发经验 各类数据库相关方案的编写,管理及实施 数据中心数据库日常运维、大型项目割接、性能优化等方面有丰富的实战经验 客户包括: 电信,银行,保险,航空,国网,汽车,烟草等 想要一起学习探讨数据安全技术的请加qq群 256041954
全部博文(163)
分类: Oracle
2016-03-31 23:24:51
'gc current request'<='gc buffer busy acquire'<='enq: TA - contention'
这个等待关系与hanganalyze是一致的。
- 根据以上分析得到session等待关系,可以确定数据库hang的原因是oracle已知问题Bug
13787307 - Hang in RAC with 'gc current request'<='gc buffer busy acquire' signature.
- 解决方法:
安装 或者 设置_gc_bypass_readers=false临时规避这个问题。
另外,在11.2低版本中也有些类似的已知问题,建议安装最新patch set (11.2.0.3/4) + 最新PSU 。
Patch set和PSU信息请参考:Oracle Recommended Patches -- Oracle Database ()
看到出现大量gc buffer busy等待,与单实例不同,在RAC环境中,由于多节点的原因,会因为节点间的资源争用产生GC类的等待,而这其中,GC Buffer Busy Waits又是最为常见的,我们看下ORACLE官方对这个等待事件的解释:
gc buffer busy:
This wait event,also known as global cache buffer busy prior to Oracle 10g,specifies the time the remote instance locally spends accessing the requested data block. This wait event is very similar to the buffer busy waits wait event in a single-instance database 。
那么如何解决gc buffer busy带来的性能问题?一般有两种方法:
一、分割应用
就是指把出现gc buffer busy等待的SQL,单独配置一个数据源,在执行的时候指定到集群中的某一个实例。在执行产生gc buffer busy的SQL的时候,使用这个数据源。
这样的缺点是,如果指向一个单实例,这些操作负载太高的话,一个实例可能会抗不住。
二、修改表底层结构
在问题表上加入一个字段inst_id,也就是实例编号,这个字段作为主分区字段,按照这个分区做范围分区。并且每次插入的时候给这个字段赋一个常量,也就是实例编号。
这样的缺点是,需要修改表结构,风险很大,而且如果以后扩展节点的话,还需要重新改表结构。
两种方法各有长短,需要根据实际情况选择,不过我个人还是倾向于第一种方法。