YashanDB 知识库|手把手教你回收表空间,释放磁盘的正确姿势!

在数据库运行过程中,随着数据的不断写入和删除,表空间会逐渐出现"空洞",也就是虽然数据删除了,但磁盘空间并没有真正释放。为了提升磁盘利用率,YashanDB 提供了表空间收缩功能。下面就一步步教你,如何高效回收表空间。

一、确认有没有可回收空间

首先,需要查询表空间的高水位线信息,判断是否存在可以回收的空间。

执行以下 SQL:

csharp 复制代码
select a.tablespace_name, a.high_water_mark, b.user_bytes, b.total_bytes 
from (
  select tablespace_name, max(header_block + blocks) * 8192 as high_water_mark 
  from dba_segments 
  where tablespace_name = 'USERS' 
  group by tablespace_name
) a, dba_tablespaces b 
where a.tablespace_name = b.tablespace_name;

查询结果中,如果 total_bytes 的数值明显大于 high_water_mark,说明这段差值就是可以回收的空间,单位是 byte。

二、查看回收前磁盘占用

可以通过系统命令查看当前表空间对应的数据文件大小,例如:

bash 复制代码
ls -l $YASDB_DATA/dbfiles

这样可以在回收前有一个参考值,方便后续对比变化。

三、执行空间回收操作

确定有可回收空间后,使用下面的命令收缩表空间:

sql 复制代码
ALTER TABLESPACE USERS SHRINK SPACE KEEP 200M;

注意,这里的 200M 是保留的最小空间,必须要大于当前高水位线占用的空间大小,否则回收操作会失败。

四、确认回收效果

回收完成后,再次执行高水位线查询命令,以及查看磁盘文件大小:

csharp 复制代码
select a.tablespace_name, a.high_water_mark, b.user_bytes, b.total_bytes 
from (
  select tablespace_name, max(header_block + blocks) * 8192 as high_water_mark 
  from dba_segments 
  where tablespace_name = 'USERS' 
  group by tablespace_name
) a, dba_tablespaces b 
where a.tablespace_name = b.tablespace_name;
ls -l $YASDB_DATA/dbfiles

如果 total_bytes 减少了,或者磁盘文件大小明显缩小了,就说明空间回收成功。

五、总结小贴士

回收前务必确认表空间的高水位线;

KEEP 参数一定要合理设置,防止因空间不足回收失败;

表空间收缩操作一般建议在业务低峰期执行,避免影响在线业务;

定期回收可以有效避免磁盘空间浪费,提升整体系统性能。

相关推荐
数据库知识分享者小北几秒前
AI Agent越用越笨?阿里云AnalyticDB「AI上下文工程」一招破解!
数据库
一匹电信狗30 分钟前
【MySQL】数据库表的操作
linux·运维·服务器·数据库·mysql·ubuntu·小程序
api_1800790546040 分钟前
性能优化揭秘:将淘宝商品 API 响应时间从 500ms 优化到 50ms 的技术实践
大数据·数据库·性能优化·数据挖掘
白衣鸽子41 分钟前
MySQL 时间类型深度解析:精度、时区陷阱与版本兼容
数据库·后端·mysql
冲上云霄的Jayden1 小时前
MySQL InnoDB 状态(SHOW ENGINE INNODB STATUS)深度分析与性能优化建议
数据库·mysql·性能优化·innodb
元闰子2 小时前
怎么让程序更高效地连起来?
数据库·redis·mysql
洲覆2 小时前
Redis 内存淘汰策略
开发语言·数据库·redis·缓存
胖头鱼的鱼缸(尹海文)2 小时前
数据库管理-第376期 Oracle AI DB 23.26新特性一览(20251016)
数据库·人工智能·oracle
麦聪聊数据2 小时前
浅谈SQL审核(一):SQL审核实现方式与常见工具的选择
数据库·sql
ajassi20003 小时前
开源 Linux 服务器与中间件(七)数据库--MySQL
linux·服务器·数据库·ubuntu·开源