Oracle数据库常见等待事件原因和一般解决方法之(Enq: TM – contention)

本文主要是介绍Oracle数据库常见等待事件原因和一般解决方法之(Enq: TM – contention),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通常我们判断Oracle数据库的性能是否有问题,需要衡量一些指标值。其中很重要的一个要素就是等待事件。

我们通常可以通过AWR报告或者是DBA_HIST_SYSTEM_EVENT视图来找到这些等待事件。

Top 5 Timed Foreground Events

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

                                                           Avg

                                                          wait   % DB

Event                                 Waits     Time(s)   (ms)   time Wait Class

------------------------------ ------------ ----------- ------ ------ ----------

DB CPU                                                3          64.6

control file sequential read          2,485           1      0   23.6 System I/O

SQL*Net break/reset to client           710           0      0    1.9 Applicatio

log file sync                             9           0      5    1.1 Commit

SQL*Net message to client             1,480           0      0     .3 Network

今天开始整理一下一些经常发生的等待事件的发生原因和一般性解决方法。


Enq: TM - contention

P1: Enqueue信息

P2: Object#

P3: 表或者分区表信息

- 发生的条件:

当DML(INSERT,UPDATE,DELETE,SELECT..FOR UPDATE,MERGE,LOCK TABLE等)语句执行的时候,需要获得对象表的TM锁,也就是表级锁。这是为了防止DML操作时需要访问的表被更改。

在获得TM锁的过程中发生的等待就是enq:TM – contention。

 

- 发生的原因:

一般情况下有如下几种可能。

1. 对于某些表执行DDL语句时执行了DML操作。反之则不会,DML执行的时候执行DDL会发生ORA-54.

2. 使用了Lock table语句。比如,当正在执行某些DML语句的时候,执行了Lock table,由于需要获得TM锁而发生等待。

3. 当DML语句执行的时候,对同一个对象表进行并行DML时会发生。原因是并行DML需要获取各种类型的锁。

  关于各种并行DML语句类型和需要获取锁的类型可以参考Oracle官方的文档。

  https://docs.oracle.com/en/database/oracle/oracle-database/19/vldbg/parameters-parallel-exec.html#GUID-C9A03D1A-66DA-4C73-813A-8AD5BC38952B

  Table 8-4 Locks Acquired by Parallel DML Statements

4. 外键约束上没有索引。

  在oracle早期版本的9i时代会出现这个问题,现在已经很少发生了。

5. INSERT / * + APPEND * / INTO 或者 SQL * Loader的direct path load。

   由于direct load不经过buffer cache直接读取数据文件,不允许表有任何变化,所以必须要获得排他的TM锁,获取的时候可能会发生enq:TM – contention。

 

- 问题发生时候的调查方法

问题发生的时候可以通过以下语句找到阻塞者的信息。

SELECT distinct w.tm, w.p2 OBJECT_ID, l.inst_id, l.sid, l.lmode, l.requestFROM ( SELECT p2, p3, 'TM-'||substr(p2raw,-8)||'-'||lpad(p3,8,'0') TMFROM v$session_wait WHERE event='enq: TM - contention'and state='WAITING') W, gv$lock LWHERE l.type(+)='TM'and l.id1(+)=w.p2and l.id2(+)=w.p3ORDER BY tm, lmode desc, request desc
;

注意有可能阻塞者并不只是一个。

如果发生时间点在过去,那么需要收集ASH报告,通过ASH报告的 EVENT 列来找到发生enq:TM – contention的信息,并根据BLOCKING_SESSION来特定阻塞者的session号。

 

- 解决方案

enq:TM-contention是一个和处理执行息息相关的等待事件。 只要根据上面的方法判断出发生enq:TM-contention'的session和阻塞者的session,

找到这些session 正在执行的sql语句,通过分时段执行就能避免该事件发生。比如一些能断定到需要长时间获得TM锁的处理,就放到空闲时间执行。

这篇关于Oracle数据库常见等待事件原因和一般解决方法之(Enq: TM – contention)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/159729

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验