使用C语言直接访问SGA

作者介绍:

姜刚 云和恩墨技术顾问

2017年3月加入云和恩墨,熟悉shell、perl脚本等。

为了加深对ORACLE数据库结构的了解,我们今天从C语言的角度,讲解如何使用C语言直接访问SGA。

基于的事实:

1、数据库启动后会分配共享内存(在ORACLE中称为System Global Area[SGA])

2、数据库中X$开头的表都是内存映射表

3、在Linux/Unix下提供了C的Lib库可以访问共享内存(shmat,shmdt,shmget等)

以GV$SESSION_WAIT为例

查看GV$SEESSION_WAIT的定义

通过上述创建视图信息,我们知道v$session_wait是建在X$KSUSECST和X$KSLED两个内存映射表上的,其访问路径是类似下图:

共享内存结构

获取SGA起始地址语句如下:

select ‘0x’||addr from X$KSMMEM where rownum<2;

X$KSUSECST在内存中的位置

获取X$KSUSECST起始地址:

Select min(addr) as BEGIN_ADDR from X$KSUSECST

获取在内存中的记录数:

Select count(*) as RECORD_SZ from X$KSUSECST

X$KSUSECST在内存区域的范围

每个记录数的长度:

Select to_dec(e.addr)-to_dec(s.addr) as LENGTH from (select min(addr) as addr from X$KSUSECST where rownum<2) s, (select max(addr) as addr from X$KSUSECST where rownum<3) e

获取每个字段的偏移量:

通过上述几个信息收集,我们获得了以下信息:

附录

C语言代码:

参考资料:

http://www.doc88.com/p-113695303367.html http://oraperf.sourceforge.net/

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-09-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏张善友的专栏

LINQ via C# 系列文章

LINQ via C# Recently I am giving a series of talk on LINQ. the name “LINQ via C...

2605
来自专栏java 成神之路

使用 NIO 实现 echo 服务器

4497
来自专栏张善友的专栏

Silverlight + Model-View-ViewModel (MVVM)

     早在2005年,John Gossman写了一篇关于Model-View-ViewModel模式的博文,这种模式被他所在的微软的项目组用来创建Expr...

2878
来自专栏张善友的专栏

Miguel de Icaza 细说 Mix 07大会上的Silverlight和DLR

Mono之父Miguel de Icaza 详细报道微软Mix 07大会上的Silverlight和DLR ,上面还谈到了Mono and Silverligh...

2667
来自专栏闻道于事

js登录滑动验证,不滑动无法登陆

js的判断这里是根据滑块的位置进行判断,应该是用一个flag判断 <%@ page language="java" contentType="text/html...

6568
来自专栏杨龙飞前端

scrollto 到指定位置

2474
来自专栏张善友的专栏

Mix 10 上的asp.net mvc 2的相关Session

Beyond File | New Company: From Cheesy Sample to Social Platform Scott Hansel...

2517
来自专栏pangguoming

Spring Boot集成JasperReports生成PDF文档

由于工作需要,要实现后端根据模板动态填充数据生成PDF文档,通过技术选型,使用Ireport5.6来设计模板,结合JasperReports5.6工具库来调用渲...

1.2K7
来自专栏我和未来有约会

Kit 3D 更新

Kit3D is a 3D graphics engine written for Microsoft Silverlight. Kit3D was inita...

2496
来自专栏跟着阿笨一起玩NET

c#实现打印功能

2612

扫码关注云+社区