Oracle 存储体系架构概述

1.1、存储层次结构

Oracle数据库的存储结构采用层次化设计,从大到小依次为:表空间 → 段 → 区 → 数据块。理解这一层次关系是掌握Oracle存储管理的基础。

|---------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------|
| 层次 | 对象 | 说明 | 典型大小 |
| 第1层 | 表空间 (Tablespace) | 逻辑存储容器,由一个或多个数据文件组成 | 数GB ~ 数TB |
| 第2层 | 段 (Segment) | 存储特定数据库对象的数据,如表段、索引段 | 数MB ~ 数GB |
| 第3层 | 区 (Extent) | 一组连续的数据块,段空间分配的最小单位 | 64KB ~ 64MB |
| 第4层 | 块 (Block) | 最小I/O单位,Oracle读写的最小粒度 | 2KB ~ 32KB(默认8KB) |

实例:理解存储层次结构

**S --- Situation(场景):**某电商公司数据库DBA接到任务:一张订单表orders(约500GB)查询性能急剧下降,需要优化存储结构。

**T --- Task(任务):**分析orders表的存储层次,找出性能瓶颈所在。

**A --- Action(行动):**通过查询DBA_SEGMENTS定位段信息,发现该表存在大量碎片化的Extent(超过10万个),且分布在不同的数据文件中。进一步检查DBA_EXTENTS,发现区大小不均匀,部分仅64KB,导致大量零散I/O。

**R --- Result(结果):**将orders表迁移到使用统一区大小(Uniform 1MB)的表空间,并启用ASSM自动段空间管理。迁移后Extent数量减少至约50万个连续区,查询性能提升约40%。

1.2、逻辑存储 vs 物理存储

Oracle存储分为逻辑结构和物理结构两个维度:

  • **逻辑层:**逻辑结构:表空间、段、区、块 ------ 面向数据库对象
  • **物理层:**物理结构:数据文件、控制文件、重做日志 ------ 面向操作系统
  • **中间层:**ASM(自动存储管理):Oracle提供的卷管理和文件系统,统管物理存储
相关推荐
这个DBA有点耶2 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵5 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils5 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
Databend1 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
ClouGence2 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将2 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils3 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波3 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_4 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_7 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库