百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

ORACLE内核解密之表空间管理

moboyou 2025-03-03 11:09 12 浏览

一、ORACLE表空间管理

1、本地表空间管理tablespace(LMT)

LMT是通过把EXTENT MANAGEMENT LOCAL子句添加到tablespace的定义句法而实现的。和原来由字典管理的tablespace(DMT)不同,LMT会将扩展管理自动化,并保持Oracle DBA不会被用来指定管理扩展大小的NEXT存储参数。这个原则唯一的例外是在NEXT和MINEXTENTS一起用在表格创建的时候。

2、自动区段空间管理(ASSM)

ASSM的tablespace是通过将SEGMENT SPACE MANAGEMENT AUTO子句添加到tablespace的定义句法里而实现的。通过使用位图freelist取代传统单向的链接列表freelist,ASSM的tablespace会将freelist的管理自动化,并取消为独立的表格和索引指定PCTUSED、FREELISTS和FREELIST GROUPS存储参数的能力。

现在ORACLE基本都是ASSM表空间管理,下面我们讨论ASMM表空间管理。

二、自动区段空间管理

1、ASSM结构

ASSM整体结构是由三层位图快和数据块组成。第一层位图块L3块,一块L3块存放多个L2块地址,一个L2块地址存放多个L1块地址,结构示意图如下:

ORACLE一般通过以下几步将数据插入数据库中块的:

第一步:查找数据字典(DBA_SEGMENTS)定位段头(L3)的位置

第二步:在段头中找到L2的位置

第三步:在L2块中根据进程PID号,做HASH运算得到一个随机数A,然后根据随机数找到对应A的L1块地址信息

第四步:根据对应的L1块信息,再次根据进程PID号,做HASH运算得到一个随机数B,然后根据B找到对应数据库块M地址信息

第五步:向第M块插入数据

以上步骤中L3块一般只有一个,一个L3块中有多个L2块一般只有当一个L2用完才会选择第二个L2块,此处不是随机选择,在L2中选择L1时通过HASH算法就是随机选择了,在L1中选择数据块也是通过HASH算法,所以此处也是随机选择,如果一个L2块中有50个L1块地址信息,一个L1中有50数据块地址信息,那么久可以支持同时2500个进程PID同时插入,这就是ORALCE数据所说的支持高并发的原理。

2、ASSM案例

我们建立一个表空间管理方式为ASSM的表空间为50M区大小为1M

 
CREATE TABLESPACE LIUXIAOBIN0724 DATAFILE 'F:\360Downloads\ORACLE\LIUXIAOBIN0724_01.DBF' SIZE 50M REUSE UNIFORM SIZE 1M;

CREATE TABLE LUXIAOBIN0724(ID INT,NAME VARCHAR2(20)) TABLESPACE LIUXIAOBIN0724;

查看区占用情况

SELECT EXTENT_ID, --区ID
       FILE_ID, --文件ID
       BLOCK_ID, --第一个块ID
       BLOCKS --块数
  FROM DBA_EXTENTS
 WHERE SEGMENT_NAME = 'LUXIAOBIN0724' --表名
 ORDER BY EXTENT_ID

我们分别DUMP块128,129,130,131看看块类型(L1,L2,L3)

ALTER SYSTEM DUMP DATAFILE 'F:\360Downloads\ORACLE\LIUXIAOBIN0724_01.DBF' block 128;
ALTER SYSTEM DUMP DATAFILE 'F:\360Downloads\ORACLE\LIUXIAOBIN0724_01.DBF' block 129;
ALTER SYSTEM DUMP DATAFILE 'F:\360Downloads\ORACLE\LIUXIAOBIN0724_01.DBF' block 130;
ALTER SYSTEM DUMP DATAFILE 'F:\360Downloads\ORACLE\LIUXIAOBIN0724_01.DBF' block 131;

根据DUMP文件可知128和129号块为L1

根据DUMP文件可知130号块为L2块131块为段头块L3

此时向表中插入数据:

INSERT INTO LUXIAOBIN0724 VALUES(1,'BBBBBB');

COMMIT;

SELECT * FROM LUXIAOBIN0724;

查看数据插入的那个块

SELECT DBMS_ROWID.ROWID_RELATIVE_FNO(ROWID) FILEID, --文件ID
DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID) BLOCK_ID,--块id
DBMS_ROWID.ROWID_ROW_NUMBER(ROWID) ROW_ID,--行ID
ID
FROM LUXIAOBIN0724;

换一个会话插入一行数据;

INSERT INTO LUXIAOBIN0724 VALUES(2,'CCCCCC');

COMMIT;

查看不同会话插入的块情况:

再次用第一个会话插入一条数据并查看插入的块情况;

根据实验我们知道,同一个会话插入的是同一个块,不同会话插入的是不同的,所以ASSM在在同一个会话大量插入数据时可能导致BUFFER BUSY WAITS,

大家可以思考我们搞数据库的常常会遇到一个问题:比如一个应用刚上班的时候,系统经常出现BUFFER BUSY WAITS,到下午了系统使用的人更多了反而不会出现BUFFER BUSY WAITS.这个问题在上面的实验大家深入实验可以找到答案。

我先做结论,大家有兴趣的可以继续深入实验:ASSM的L1中数据块的多少是根据表大小来定的,表越大,L1中数据块越多,越多的话随机插入不同数据块的可能性越大,反之同时插入一个块的可能性就越大,就容易出现BUFFER BUSY WAITS,普通插入数据的时候是在高水位现之下,找空闲数据块插入,高水位线位于L1块最后一个块位置,L1中HASH算法只在高水位线之下找空闲块,所以要高并发,需要提高高水位线,和L1中数据块数。

相关推荐

cvpr 2024|注意力校准用于解缠结的文本到图像个性化

AttentionCalibrationforDisentangledText-to-ImagePersonalization研究背景近年来,大规模文本到图像(T2I)模型取得了显著进展,能...

1080P的显示,4K的享受?NVIDIA DSR游戏实测!

游戏玩家对画质的要求越来越高,因此每到新一代显卡推出的时候,除了游戏性能的提升之外,也会采用提升画质的新技术。NVIDIA最新的Geforce900系列显卡也不例外,一起推出的DSR技术号称可以在1...

「学习OpenCV4」OpenCV线性滤波与非线性滤波总结

本文分享内容来自图书《学习OpenCV4:基于Python的算法实战》,该书内容如下:第1章OpenCV快速入门;第2章图像读写模块imgcodecs;第3章核心库模块core;第4章...

增益映射耦合局部正则化的图像重构算法

朱莉(西安科技大学计算机学院,陕西西安710054)摘要:针对当前的图像重构方法在对多帧超分辨率图像复原时,存在明显的模糊效应与振铃效应的不足,提出增益映射控制耦合局部正则化的图像重构算法。首...

图像处理——5种常见的平滑滤波

平滑滤波是一种简单又常见的图像处理操作。平滑图像的目的有很多,但通常都是为了减少噪声和伪影。在OpenCV中共有5种平滑滤波操作,分别是以下几种:测试代码如下:#include<iostream...

C# 图像处理技术——简单的滤波去噪

在C#中,可以使用System.Drawing命名空间中的类来进行图像处理和滤波去噪操作。以下是一个示例代码,演示如何使用平均滤波器进行简单的去噪处理:usingSystem.Drawing;us...

Java,OpenCV,图像模糊,归一化均值滤波,中值滤波器,高斯模糊

图像模糊图像模糊是图像处理中最简单和常用的操作之一,其主要目的之一是给图像预处理的时候降低图像噪声。图像模糊方法可以总结如下:1、归一化均值滤波器(API为blur())2、高斯滤波器(API为Ga...

带频偏校准的GMSK解调器设计与实现

郑婧怡1,高绍全1,姜汉钧1,张春1,王志华1,2,贾雯2(1.清华大学微电子所,北京100084;2.深圳清华大学研究院,广东深圳518055)摘要:提出了一种在零中频低功耗蓝牙接收机中使用...

图像滤波去噪方法及应用场景

在图像处理中,不同滤波方法针对不同类型的噪声和场景具有特定优势。以下是三种常见滤波器的特点和应用场景总结:1.高斯滤波(GaussianFilter)原理:基于高斯函数的加权平均,对邻域像素进行平...

多体系统动力学仿真软件(DAP)

多体系统动力学仿真软件(DAP)-北京西交智众软件科技有限公司–DAP软件简介DAP(DynamicsAnalysisPlatform)软件,源自西南交通大学沈志云院士带队轨道交通运载系统全国...

精品博文图文详解Xilinx ISE14.7 安装教程

在软件安装之前,得准备好软件安装包,可从Xilinx官网上下载:http://china.xilinx.com/support/download/index.html/content/xilinx/z...

酷睿 Ultra 5 和 Ultra 7,或者i5和i7差距多大?

#我来唠家常#提到ultra,我觉得看这个题目,应该主打轻薄本,或者设计本。分两个问题看:ultra7或者i7的优势,ultra相对老款处理器的优势Ultra7的最大优势是:多了2个大核心,这两个大...

直流-直流(DC-DC)变换电路

直流-直流(DC-DC)变换电路,可以将一种直流电源经过变换电路后输出另一种具有不同输出特性的直流电源,可以是一种固定电压或可调电压的直流电。按照电路拓扑结构的不同,DC-DC变换电路可以分成两种形式...

Energies CL致命错误

期刊基础信息·刊号:ISSN1996-1073·全称:Energies·影响因子:3.2·分区:Q2(能源与燃料类)·版面费:2200瑞士法郎·年发文量:约4500篇CoverLett...

基于心电脉搏信号的无创血压算法研究

洋洋,陈小惠(南京邮电大学自动化学院,江苏南京210023)摘要:针对人体血压无创检测问题,提出了一种基于心电信号(Electrocardiogram,ECG)与光电容积脉搏波(Photople...