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提供的卷管理和文件系统,统管物理存储
相关推荐
zt1985q1 小时前
本地部署开源数据库管理工具 DBeaver 并实现外部访问( Windows 版本)
运维·服务器·网络·数据库·网络协议
珂玥c1 小时前
新增硬盘有脏数据如何处理——ubuntu16.04
linux·数据库·ide
东风破1371 小时前
DM8事务管理,多版本并发控制,及达梦开发接口
数据库·dm达梦数据库
城数派1 小时前
省市县三级的逐年植被覆盖度(FVC)数据
数据库·arcgis·信息可视化·数据分析
2301_769340672 小时前
HTML函数运行时触控屏失灵是硬件故障吗_输入层兼容性测试【详解】
jvm·数据库·python
lifewange3 小时前
SQL Server介绍
数据库
Rubin智造社4 小时前
Claude Code开发者大会系列2|“饮鸩止渴”还是“即刻解药”?Anthropic与SpaceX的联姻内幕
大数据·数据库·人工智能·开发者大会·anthropic·claude code
噢,我明白了4 小时前
表单的完整 CRUD 练习【极简个人记账本】(含前端后端链接mySQL)
java·前端·数据库·mysql
2301_809204706 小时前
bootstrap怎么实现鼠标悬停切换图片预览功能
jvm·数据库·python