千家信息网

如何解决library cache pin及library cache lock故障

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,这期内容当中小编将会给大家带来有关如何解决library cache pin及library cache lock故障,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
千家信息网最后更新 2025年01月23日如何解决library cache pin及library cache lock故障

这期内容当中小编将会给大家带来有关如何解决library cache pin及library cache lock故障,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

某个客户, 突然发生前端零售业务卡顿的情况。因为当时在处理其他客户的事宜, 所以当时没有进行monitor。由另外一位同事进行处理, 直接紧急重启了应用。
问题解决。但是业务不得已中断。
事后调查原因, 从卡顿的时间段来看发现大量的library cache pin等待事件,并且伴有library cache lock。

另外,同事也保存了阻塞相关的会话信息
create table block_sess1018 as
select * from v$session where blocking_session is not null
结合
select * from dba_hist_active_sess_history h where h.sample_time > to_date('20171018 15:25:00', 'yyyymmdd hh34:mi:ss')
and h.sample_time < to_date('20171018 16:00:00', 'yyyymmdd hh34:mi:ss') and event like 'library cache%'

library cache pin几个参数的意思:

p1=handle address
p2=pin address
p3=namespace&&encoded mode

对于p1raw可以对应于x$kglob中的KGLHDADR字段x$kglpn中的KGLPNHDL字段,x$kgllk中的KGLLKHDL字段,后边有sql关联。

dba_hist_active_sess_history中的P1可以转换成16进制之后,再去v$object_dependency通过to_address定位到pin的对象


SQL> select s.sid, s.saddr, sw.p1raw
from v$session_wait sw, v$session s
where sw.sid = s.sid and sw.event='library cache pin';

SID SADDR P1RAW
---------- ---------------- ----------------
53 0000000077204A80 000000006DBC5BE8

Now using the P1RAW and SADDR values find the the address of the user session that is holding the lock

SQL> select b.KGLLKUSE from dba_kgllock w , dba_kgllock b
where w.KGLLKHDL = b.KGLLKHDL
and w.KGLLKREQ > 0 and b.KGLLKMOD > 0
and w.KGLLKTYPE = b.KGLLKTYPE
and w.KGLLKUSE = '0000000077204A80' -- SADDR
and w.KGLLKHDL = '000000006DBC5BE8' -- P1RAW

select to_owner, to_name from v$object_dependency
where to_address = '000000016B500270';

select * from dba_ddl_locks where owner = 'HR';

找到了library cache pin的对象。

再进一步发现(通过logminer挖掘日志),故障开始前,有开发的同事对一个基础表进行了DDL操作,引发了其后一连串的编译的动作(有很多对象依赖于此表)。
很多对象,比如触发器(产品的逻辑很多是用触发器完成), 过程,函数,视图等依赖于此表。
由于此时正值业务高峰,所以出现了大面积的卡顿。

以下是DDL时间顺序




执行的DDL语句:

上述就是小编为大家分享的如何解决library cache pin及library cache lock故障了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。

对象 故障 业务 同事 字段 内容 客户 时间 触发器 卡顿 分析 处理 一连串 不得已 再进一步 中小 事件 事宜 内容丰富 函数 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 你为什么选择软件开发知乎 虹口区技术软件开发管理系统 数据库查询操作中简历字段清空 河南商业软件开发零售价格 opc新建数据库 公司软件开发资质查询 戴尔服务器蓝屏进不去怎么办 舆情监控软件开发 互联网行业科技发展 为什么进游戏显示服务器人数已满 达梦数据库客户端启动命令 远离毒品网络安全 电脑上怎么用vpn服务器 3线城市做软件开发公司吗 软件开发的需求清单 网络安全伴我行手抄报初中 软件开发耗费精力 陕西字节互联网络科技有限公司 淘宝采用的网络安全协议 服务器插上无线网卡启用不了 索尼新机影像数据库文件错误 数据库问题集锦 网络技术上网日志 软件开发如何识别客户需求 软件开发网站模版 第12章面向方面的软件开发 学生网络安全ppt课件免费 阴阳师手游连接服务器失败怎么办 互联网科技mcn创业孵化 有关网络安全的是
0