[20180625]oradebug peek 2.txt

简介: [20180625]oradebug peek 2.txt --//上个星期演示了oradebug peek查看内存数据块的情况,oradebug peek {address} length 1,最后的参数1可以实现转储到跟踪文件.

[20180625]oradebug peek 2.txt

--//上个星期演示了oradebug peek查看内存数据块的情况,oradebug peek {address} length 1,最后的参数1可以实现转储到跟踪文件.
--//以前也使用oradebug查看sql语句在共享池的父游标.采用拚接的方式查看.
--//如果使用上面的方式就简单了,测试看看.
--//以前的测试,链接:[20161230]查看父游标中sql语句.txt => http://blog.itpub.net/267265/viewspace-2131655/

1.环境:
SCOTT@book> @ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

2.查看父游标中sql语句:
SCOTT@book> select * from dept where deptno=10;
    DEPTNO DNAME          LOC
---------- -------------- -------------
        10 ACCOUNTING     NEW YORK

--//多执行几次,保持sql语句光标在共享池中,确定sql_id= 4xamnunv51w9j.

SYS@book> @ &r/sharepool/shp4 4xamnunv51w9j 0
TEXT           KGLHDADR         KGLHDPAR         C40                                        KGLHDIVC KGLOBHD0         KGLOBHD6           KGLOBHS0   KGLOBHS6   KGLOBT16   N0_6_16        N20   KGLNAHSH KGLOBT03        KGLOBT09
-------------- ---------------- ---------------- ---------------------------------------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ----------
子游标句柄地址 000000007B9C0FD8 000000007C6315A8 select * from dept where deptno=10                0 000000007C25EC10 000000007DBA6D20       4528      12144       3067     19739      19739  911274289 4xamnunv51w9j          0
父游标句柄地址 000000007C6315A8 000000007C6315A8 select * from dept where deptno=10                0 000000007D84C448 00                     4720          0          0      4720       4720  911274289 4xamnunv51w9j      65535

--//父游标地址=000000007C6315A8

4.看看范围:
--//通过查询xksmspSELECTFROMxksmsp WHERE TO_NUMBER ('000000007C6315A8', 'xxxxxxxxxxxxxxxx') between TO_NUMBER(KSMCHPTR, 'xxxxxxxxxxxxxxxx') and TO_NUMBER(KSMCHPTR, 'xxxxxxxxxxxxxxxx')+KSMCHSIZ

ADDR                   INDX    INST_ID   KSMCHIDX   KSMCHDUR KSMCHCOM         KSMCHPTR           KSMCHSIZ KSMCHCLS   KSMCHTYP KSMCHPAR
---------------- ---------- ---------- ---------- ---------- ---------------- ---------------- ---------- -------- ---------- ----------------
00007FDE14C240E8      13208          1          1          1 KGLHD            000000007C631578        560 recr             80 00

--//可以确定范围: 0x000000007C631578,0x000000007C631578+560.

--//先看看sql语句转储的内容:
SCOTT@book> select dump('select * from dept where deptno=10',16) from dual ;
DUMP('SELECT*FROMDEPTWHEREDEPTNO=10',16)
--------------------------------------------------------------------------------------------------------------------
Typ=96 Len=34: 73,65,6c,65,63,74,20,2a,20,66,72,6f,6d,20,64,65,70,74,20,77,68,65,72,65,20,64,65,70,74,6e,6f,3d,31,30

--//我使用的cpu是intel系列的,存在大小头问题,在内存中看到的应该4个字节4个字节颠倒.前面4个应该是65,6c,65,73(16进制).
--//BTW: 我的测试oradebug peek最多查询60个字节.

SYS@book> oradebug setmypid
Statement processed.

SYS@book> oradebug peek 0x000000007C631578 560 1
[07C631578, 07C6317A8) = 00000231 80B38F00 7C631500 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00080050 803CBD30 00000000 ...
SYS@book> oradebug tracefile_name
/u01/app/oracle/diag/rdbms/book/book/trace/book_ora_7077.trc

5.查看转储:

*** 2018-06-25 09:05:02.603
Processing Oradebug command 'peek 0x000000007C631578 560 1'
[07C631578, 07C6317A8) = 00000231 80B38F00 7C631500 00000000 00000000 ...
Dump of memory from 0x07C63158C to 0x07C6317A8
07C631580                            00000000              [....]
07C631590 00000000 00000000 00000000 00000000  [................]
07C6315A0 00000000 00080050 803CBD30 00000000  [....P...0.<.....]
07C6315B0 803CBD30 00000000 7DBA6660 00000000  [0.<.....`f.}....]
07C6315C0 7C631700 00000000 00010000 10012841  [..c|........A(..]
07C6315D0 00000001 00000001 00010001 00000002  [................]
07C6315E0 00000000 00000005 00010000 00000000  [................]
07C6315F0 00000000 00000000 7C631778 00000000  [........x.c|....]
07C631600 00000001 00000000 7C631608 00000000  [..........c|....]
07C631610 7C631608 00000000 7C631618 00000000  [..c|......c|....]
07C631620 7C631618 00000000 7BF9D778 00000000  [..c|....x..{....]
07C631630 7BF9D778 00000000 7C631638 00000000  [x..{....8.c|....]
07C631640 7C631638 00000000 7D654A40 00000000  [8.c|....@Je}....]
07C631650 7D654A40 00000000 00000000 00000000  [@Je}............]
07C631660 00000001 00000000 4EAA74D5 00000000  [.........t.N....]
07C631670 0000F131 00000000 7C6316E8 00000000  [1.........c|....]
07C631680 7C631680 00000000 7C631680 00000000  [..c|......c|....]
07C631690 7C631690 00000000 7C631690 00000000  [..c|......c|....]
07C6316A0 00000000 00000000 7FC47F68 00000000  [........h.......]
07C6316B0 00000000 00000000 00000000 00000000  [................]
07C6316C0 00000003 00000001 00020002 00000000  [................]
07C6316D0 00000001 00000000 00000000 00000000  [................]
07C6316E0 00000000 00000000 00000000 00000000  [................]
07C6316F0 00000021 00000000 3650F131 00000000  [!.......1.P6....]
07C631700 1431C45D BDDBB9E7 4EAA74D5 3650F131  [].1......t.N1.P6]
07C631710 00000000 19067678 0011030A 00000000  [....xv..........]
07C631720 00000000 00000000 00000023 00000000  [........#.......]
07C631730 00000000 00000000 00000000 00000000  [................]
07C631740 7C631750 00000000 3650F131 00000053  [P.c|....1.P6S...]
07C631750 656C6573 2A207463 6F726620 6564206D  [select * from de]
07C631760 77207470 65726568 70656420 3D6F6E74  [pt where deptno=]
07C631770 00003031 00000000 00000000 00000000  [10..............]
07C631780 00000000 00000000 00000000 00000000  [................]
        Repeat 1 times
07C6317A0 00000000 00000000                    [........]

--//可以发现sql语句的内容.

*** 2018-06-25 09:05:02.604
Oradebug command 'peek 0x000000007C631578 560 1' console output:
[07C631578, 07C6317A8) = 00000231 80B38F00 7C631500 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00080050 803CBD30 00000000 ...

*** 2018-06-25 09:05:12.659
Processing Oradebug command 'tracefile_name'

--//通过这样的方式提供快捷的方式查看内存地址的相关内容.

目录
打赏
0
0
0
0
36
分享
相关文章
Oracle/Mysql迁移到Postgresql事务回滚行为差异(开发避坑系列)
Mysql或Oracle迁移到Postgresql系产品后,经常会发生事务回滚导致的问题,具体问题一般都是类似于: **为什么我没rollback,我的事务就自己回滚了?** 下面我举一个简单的例子,说明下PG和其他两款DB在事务回滚行为上的差异 ## Oracle事务内报错后的行为 (完整代码贴在文章最后) ```java Class.fo
1139 0
2025年最新版最细致Maven安装与配置指南(任何版本都可以依据本文章配置)
本文详细介绍了Maven的项目管理工具特性、安装步骤和配置方法。主要内容包括: Maven概述:解释Maven作为基于POM的构建工具,具备依赖管理、构建生命周期和仓库管理等功能。 安装步骤: 从官网下载最新版本 解压到指定目录 创建本地仓库文件夹 关键配置: 修改settings.xml文件 配置阿里云和清华大学镜像仓库以加速依赖下载 设置本地仓库路径 附加说明:包含详细的配置示例和截图指导,适用于各种操作系统环境。 本文提供了完整的Maven安装和配置
2025年最新版最细致Maven安装与配置指南(任何版本都可以依据本文章配置)
Go语言实战指南 —— Go中的反射机制:reflect 包使用
Go语言中的反射机制通过`reflect`包实现,允许程序在运行时动态检查变量类型、获取或设置值、调用方法等。它适用于初中级开发者深入理解Go的动态能力,帮助构建通用工具、中间件和ORM系统等。
132 62
电脑没有有效IP配置,连不上网怎么办?,解决办法
当电脑出现“本地连接没有有效的IP配置”错误时,通常表示无法正常获取或配置IP地址,导致无法上网。本文介绍了常见原因及解决方法,包括重启路由器和电脑、手动设置IP地址、更新或重新安装网卡驱动、检查DHCP服务是否开启等步骤,帮助你快速恢复网络连接。
145 59
iTop Easy Desktop桌面整理软件,桌面管理软件,壁纸管理教程
iTop Easy Desktop 是一款多功能桌面整理软件,支持图标分组、自动分类、快速搜索、多页面管理、壁纸切换及隐私保护等功能,帮助用户高效管理桌面,提升使用体验。
214 65
Dify MCP 保姆级教程来了!
大语言模型,例如 DeepSeek,如果不能联网、不能操作外部工具,只能是聊天机器人。除了聊天没什么可做的。
163 2
🌼通义千问获信通院最高等级大模型安全认证
阿里巴巴通义千问荣获中国信通院“大规模预训练模型(文本生成功能)安全认证证书”,达最高等级——增强级。测评依据工信部CCSA行业标准,覆盖59种内容安全风险。通义千问在抵御指令注入和越狱攻击方面表现突出,得益于阿里云构建的全生命周期安全体系。同时,阿里云通过ISO/IEC 42001认证,成为全球首家获此殊荣的企业,彰显其AI管理水平与技术应用的国际领先性。通义千问已广泛应用于互联网、汽车、政务等领域,持续优化安全机制,推动行业智能化发展。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问