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提供的卷管理和文件系统,统管物理存储
相关推荐
小马爱打代码9 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
海南java第二人11 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat11 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中12 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪12 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客13 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP14 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_14 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬14 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存