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提供的卷管理和文件系统,统管物理存储