数据库学习日常案例20231206- 单实例oradebug hanganalize 3 分析

1 创建测试存储过程

SQL> create or replace procedure p0001 as
  2  begin
  3  dbms_lock.sleep(300000); --1000 seconds
  4  end;
  5  /

过程已创建。

2 session1调用存储过程

call p0001();

3 SESSION2和3分被对存储进行重新编译。

SQL> alter procedure p0001 compile;

发现编译存储过程均被hang住。

4 使用oradebug hanganalyze 3分析

SQL> oradebug hanganalyze 3;
Hang Analysis in D:\APP\ADMINISTRATOR\VIRTUAL\diag\rdbms\oprod\oprod\trace\oprod_ora_10320.trc
SQL> exit
从 Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production 断开

C:\Users\Administrator>

5 分析trc文件

Trace file D:\APP\ADMINISTRATOR\VIRTUAL\diag\rdbms\oprod\oprod\trace\oprod_ora_10320.trc
Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production
Build label:    RDBMS_12.2.0.1.0_WINDOWS.X64_170210.4
Windows NT Version V6.1 Service Pack 1 
ORACLE_HOME =  D:\app\Administrator\virtual\product\12.2.0\dbhome_1
Node name           : UP57VFMG5AH8GDS
CPU                 : 4 - type 8664, 2 Physical Cores
Process Affinity    : 0x0x0000000000000000
Memory (Ava
Instance name: oprod
Redo thread mounted by this instance: 1
Oracle process number: 54
Windows thread id: 10320, image: ORACLE.EXE (SHAD)


*** 2023-12-06T15:52:29.155541+08:00
*** SESSION ID:(262.24957) 2023-12-06T15:52:29.155541+08:00
*** CLIENT ID:() 2023-12-06T15:52:29.155541+08:00
*** SERVICE NAME:(SYS$USERS) 2023-12-06T15:52:29.155541+08:00
*** MODULE NAME:(sqlplus.exe) 2023-12-06T15:52:29.155541+08:00
*** ACTION NAME:() 2023-12-06T15:52:29.155541+08:00
*** CLIENT DRIVER:(SQL*PLUS) 2023-12-06T15:52:29.155541+08:00
 
Processing Oradebug command 'setmypid'

*** 2023-12-06T15:52:29.156541+08:00
Oradebug command 'setmypid' console output: <none>

*** 2023-12-06T15:52:54.968017+08:00
Processing Oradebug command 'hanganalyze level 3'

*** 2023-12-06T15:52:54.971017+08:00
Error while executing Oradebug command 'hanganalyze level 3':
ORA-01858: 鍦ㄨ姹傝緭鍏ユ暟瀛楀鎵惧埌闈炴暟瀛楀瓧绗?

*** 2023-12-06T15:52:54.972017+08:00
Oradebug command 'hanganalyze level 3' console output: <none>

*** 2023-12-06T15:52:59.373269+08:00
Processing Oradebug command 'hanganalyze '

*** 2023-12-06T15:52:59.374269+08:00
===============================================================================
HANG ANALYSIS:
  instances (db_name.oracle_sid): oprod.oprod
  no oradebug node dumps
  analysis initiated by oradebug
  os thread scheduling delay history: (sampling every 1.000000 secs)
    0.000000 secs at [ 15:52:59 ]
      NOTE: scheduling delay has not been sampled for 0.222575 secs
    0.000000 secs from [ 15:52:55 - 15:53:00 ], 5 sec avg
    0.000000 secs from [ 15:51:59 - 15:53:00 ], 1 min avg
    0.000000 secs from [ 15:47:59 - 15:53:00 ], 5 min avg
  vktm time drift history
===============================================================================
 
Chains most likely to have caused the hang:
 [a] Chain 1 Signature: 'PL/SQL lock timer'<='library cache pin'<='library cache lock'
     Chain 1 Signature Hash: 0x38f0a7dd
 
===============================================================================
Non-intersecting chains:
 
-------------------------------------------------------------------------------
Chain 1:
-------------------------------------------------------------------------------
    Oracle session identified by:
    {
                instance: 1 (oprod.oprod)
                   os id: 2880
              process id: 27, ORACLE.EXE (SHAD)
              session id: 389
        session serial #: 26175
    }
    is waiting for 'library cache lock' with wait info:
    {
                      p1: 'handle address'=0x7ff13aebae8
                      p2: 'lock address'=0x7ff143eb1d0
                      p3: '100*mode+namespace'=0x130ce00010003
            time in wait: 1 min 4 sec
           timeout after: 13 min 55 sec
                 wait id: 18
                blocking: 0 sessions
            wait history:
              * time between current wait and wait #1: 0.000332 sec
              1.       event: 'PGA memory operation'
                 time waited: 0.000006 sec
                     wait id: 17               p1: ''=0x10000
                                               p2: ''=0x2
              * time between wait #1 and #2: 0.000017 sec
              2.       event: 'PGA memory operation'
                 time waited: 0.000004 sec
                     wait id: 16               p1: ''=0x10000
                                               p2: ''=0x1
              * time between wait #2 and #3: 0.002372 sec
              3.       event: 'SQL*Net message from client'
                 time waited: 1 min 58 sec
                     wait id: 15               p1: 'driver id'=0x42455100
                                               p2: '#bytes'=0x1
    }
    and is blocked by
 => Oracle session identified by:
    {
                instance: 1 (oprod.oprod)
                   os id: 13020
              process id: 56, ORACLE.EXE (SHAD)
              session id: 15
        session serial #: 38764
    }

alter system kill session '15,38764' immediate;
    which is waiting for 'library cache pin' with wait info:
    {
                      p1: 'handle address'=0x7ff13aebae8
                      p2: 'pin address'=0x7ff13b78178
                      p3: '100*mode+namespace'=0x130ce00010003
            time in wait: 1 min 9 sec
           timeout after: 13 min 50 sec
                 wait id: 29
                blocking: 1 session
            wait history:
              * time between current wait and wait #1: 0.000282 sec
              1.       event: 'PGA memory operation'
                 time waited: 0.000006 sec
                     wait id: 28               p1: ''=0x10000
                                               p2: ''=0x1
              * time between wait #1 and #2: 0.000477 sec
              2.       event: 'SQL*Net message from client'
                 time waited: 16.107334 sec
                     wait id: 27               p1: 'driver id'=0x42455100
                                               p2: '#bytes'=0x1
              * time between wait #2 and #3: 0.000007 sec
              3.       event: 'SQL*Net message to client'
                 time waited: 0.000001 sec
                     wait id: 26               p1: 'driver id'=0x42455100
                                               p2: '#bytes'=0x1
    }
    and is blocked by
 => Oracle session identified by:
    {
                instance: 1 (oprod.oprod)
                   os id: 10480
              process id: 55, ORACLE.EXE (SHAD)
              session id: 385
        session serial #: 46652
    }
alter system kill session '385,46652' immediate;
    which is waiting for 'PL/SQL lock timer' with wait info:
    {
                      p1: 'duration'=0x0
            time in wait: 1 min 12 sec
           timeout after: 4998 min 47 sec
                 wait id: 186
                blocking: 2 sessions
            wait history:
              * time between current wait and wait #1: 0.002311 sec
              1.       event: 'db file sequential read'
                 time waited: 0.002757 sec
                     wait id: 185              p1: 'file#'=0x1
                                               p2: 'block#'=0x18598
                                               p3: 'blocks'=0x1
              * time between wait #1 and #2: 0.001505 sec
              2.       event: 'SQL*Net message from client'
                 time waited: 7.702528 sec
                     wait id: 184              p1: 'driver id'=0x42455100
                                               p2: '#bytes'=0x1
              * time between wait #2 and #3: 0.002764 sec
              3.       event: 'SQL*Net message to client'
                 time waited: 0.000001 sec
                     wait id: 183              p1: 'driver id'=0x42455100
                                               p2: '#bytes'=0x1
    }
 
Chain 1 Signature: 'PL/SQL lock timer'<='library cache pin'<='library cache lock'
Chain 1 Signature Hash: 0x38f0a7dd
-------------------------------------------------------------------------------
 
===============================================================================
Extra information that will be dumped at higher levels:
[level  4] :   1 node dumps -- [LEAF] [LEAF_NW] 
[level  5] :   2 node dumps -- [NO_WAIT] [INVOL_WT] [SINGLE_NODE] [NLEAF] [SINGLE_NODE_NW] 
 
State of ALL nodes
([nodenum]/cnode/sid/sess_srno/session/ospid/state/[adjlist]):
[14]/1/15/38764/000007FF0490E748/13020/NLEAF/[384]
[384]/1/385/46652/000007FF044D1F50/10480/LEAF/
[388]/1/389/26175/000007FF044C8870/2880/NLEAF/[14]

*** 2023-12-06T15:52:59.379269+08:00
===============================================================================
END OF HANG ANALYSIS
===============================================================================

*** 2023-12-06T15:52:59.380269+08:00
Oradebug command 'hanganalyze ' console output: 
Hang Analysis in D:\APP\ADMINISTRATOR\VIRTUAL\diag\rdbms\oprod\oprod\trace\oprod_ora_10320.trc
 

6 分析处理

删除源头堵塞会话 

Chain 1 Signature: 'PL/SQL lock timer'<='library cache pin'<='library cache lock'

and is blocked by
 => Oracle session identified by:
    {
                instance: 1 (oprod.oprod)
                   os id: 10480
              process id: 55, ORACLE.EXE (SHAD)
              session id: 385
        session serial #: 46652
    }

    which is waiting for 'PL/SQL lock timer' with wait info:

alter system kill session '385,46652' immediate;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/201932.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解析操作系统是如何启动起来的?

操作系统被称为“第一个程序”&#xff0c;the first programme&#xff0c;原因很简单&#xff0c;只有当操作系统启动起来后才能运行我们编写的程序&#xff0c;那么你有没有想过这个问题&#xff1a;操作系统是怎样启动起来的呢&#xff1f;实际上这个过程就像发射火箭一样有…

kuboard如何部署redis?

在K8S上部署redis 如 在K8S上部署mysql 所述&#xff0c;auth-server、user-center、api-gateway 都需要使用 redis 服务&#xff0c;本文描述如何使用 Kuboard 在 Kubernetes 上部署 redis。 本文将使用 redis官方镜像 进行部署。 部署redis 在 Kuboard 界面进入名称空间 …

微信小程序实现watch监听数值改变的效果

前言 需要用到Javascript中的Object.defineProperty()方法&#xff0c;实现劫持对象的get/set指令&#xff0c;从而监听到对象的赋值(调用setter)&#xff0c;达到监听数值改变效果 示例 监听变量方法&#xff1a; function watchData(pageData, key, fn) {var oldVal pag…

Leetcode—2477.到达首都的最少油耗【中等】

2023每日刷题&#xff08;五十&#xff09; Leetcode—2477.到达首都的最少油耗 算法思想 参考自灵茶山艾府 实现代码 class Solution { public:long long minimumFuelCost(vector<vector<int>>& roads, int seats) {int n roads.size() 1;vector<i…

js函数工具-获取某年的最后一个工作日

// 获取某年的最后一个工作日 import { endOfYear, isWeekend } from date-fns; import moment from moment;const lastWorkingDayOfYear (year) > {let date endOfYear(new Date(year, 0, 1));while (isWeekend(date)) {date new Date(date.getTime() - 24 * 60 * 60 * …

iNet Network Scanner for Mac:简洁高效的WiFi网络扫描软件

随着无线网络的普及&#xff0c;WiFi网络已经成为我们日常生活中必不可少的一部分。无线网络的稳定性和速度对我们的工作和娱乐体验至关重要。因此&#xff0c;一款功能强大、简洁高效的WiFi网络扫描软件非常重要。今天&#xff0c;我们向大家推荐一款优秀的Mac平台WiFi网络扫描…

【软件测试】技术精选:Jmeter常见的几种报错

1、Java.net.UnknownHostException 这个错的含义是 没有连接到服务器地址&#xff0c;因此很可能是 内部网络中断导致。 2、502 Bad gateway 这个和本地的线程数无关 可能原因是网络抖动不稳定导致 3、java.net.SocketException: Socket closed 强制停止线程&#xff0c;连接…

Python绘图坐标轴数字要求三位分节的处理方法

比如说1000&#xff0c;用三位分节法的写法就是1 000&#xff0c;咱们操作的时候可以先式化字符串&#xff0c;用千位分隔符表示数字就是1,000&#xff0c;再把逗号换成空格。 import matplotlib.pyplot as plt import matplotlib.ticker as ticker# 示例数据 x [1000, 2000, …

vue 过滤器 (filters) ,实际开发中的使用

在实际开发中要判断不同的状态,要写很多重复的代码, 类似这样: 这样学麻烦, 不方便维护, 这时候可以用 filters 过滤器 在页面这样写就可以了

PET(Point-Query Quadtree for Crowd Counting, Localization, and More)

PET&#xff08;Point-Query Quadtree for Crowd Counting, Localization, and More&#xff09; 介绍实验记录训练阶段推断阶段 介绍 论文&#xff1a;Point-Query Quadtree for Crowd Counting, Localization, and More 实验记录 训练阶段 TODO 推断阶段 下面是以一张输…

4.8 构建onnx结构模型-Less

前言 构建onnx方式通常有两种&#xff1a; 1、通过代码转换成onnx结构&#xff0c;比如pytorch —> onnx 2、通过onnx 自定义结点&#xff0c;图&#xff0c;生成onnx结构 本文主要是简单学习和使用两种不同onnx结构&#xff0c; 下面以 Less 结点进行分析 方式 方法一&a…

Openfire CVE-2023-32315(metasploit版)

step1&#xff1a;用docker搭建环境 Step2&#xff1a;docker查看映射端口 Step3&#xff1a;打开mysql和apache2&#xff0c;访问特定端口&#xff0c;然后靶标应用。 Step4&#xff1a;用metasploit进行攻击&#xff1a; 首先&#xff0c;打开metasploit&#xff0c;然…

Java Date LocalDate LocalDateTime

Java Date LocalDate LocalDateTime Java中常用时间类型 Date LocalDate LocalDateTime 在工作中使用很频繁&#xff0c; 但中间很多常用功能每次编写代码很繁琐&#xff0c;故而封装了以下三个工具类&#xff1a; DateUtil 日期工具类LocalDateUtil 新日期工具类LocalDateTime…

Python-条件判断(if语句详解)

条件判断 python代码执行从上到下&#xff0c;默认没有main函数 如果 否则 写法一&#xff1a;if if expression: do_something1 do_something2 ... next_something#一定会执行&#xff0c;和判断条件无关 if a > b:#执行语句1#执行语句2#执行语句3#... #执行语…

java第三十课

电商项目&#xff08;前台&#xff09;&#xff1a; 登录接口 注册接口后台&#xff1a; 注册审核&#xff1a;建一个线程类 注意程序中的一个问题。 这里是 5 条记录&#xff0c;2 条记录显示应该是 3 页&#xff0c;实际操作过程 有审核机制&#xff0c;出现了数据记录动态变…

【从删库到跑路 | MySQL数据库总结篇】JDBC编程

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【MySQL学习专栏】&#x1f388; 本专栏旨在分享学习MySQL的一点学习心得&#xff0c;欢迎大家在评论区讨论&#x1f48c; 目录 一、前言…

共建共创 | 紫光展锐-中国电信“终端测试与创新联合实验室”正式成立

近日&#xff0c;紫光展锐携手中国电信正式成立“终端测试与创新联合实验室”&#xff0c;这标志着紫光展锐在功能、协议、互操作性等测试方面的创新能力和持续发展能力获得认可&#xff0c;为进一步提升通信技术&#xff0c;助推终端厂商产品加速上市奠定了坚实的基础。 2023年…

网络之路26:STP生成树协议

正文共&#xff1a;2222 字 19 图&#xff0c;预估阅读时间&#xff1a;3 分钟 目录 网络之路第一章&#xff1a;Windows系统中的网络 0、序言 1、Windows系统中的网络1.1、桌面中的网卡1.2、命令行中的网卡1.3、路由表1.4、家用路由器 网络之路第二章&#xff1a;认识企业设备…

农产品加工行业分析:我国产业总产值共计7.17万亿元

农产品加工是用物理、化学和生物学的方法&#xff0c;将农业的主、副产品制成各种食品或其他用品的一种生产活动。是农产品由生产领域进入消费领域的一个重要环节。主要包括粮食加工、饲料加工、榨油、酿造、制糖、制茶、烤烟、纤维加工以及果品、蔬菜、畜产品、水产品等的加工…

Windows创建服务(.NET8)

windows服务 Windows服务是一种在Windows操作系统中运行的后台程序&#xff0c;用于在系统启动时启动并在系统关闭时关闭。这些服务可以是Microsoft自己的服务&#xff0c;也可以是第三方软件的服务。它们在后台运行&#xff0c;通常不需要交互式用户界面。 Windows服务通常用…