关于表空间管理的详细语法描述请参考开发手册CREATE TABLESPACE、ALTER TABLESPACE、DROP TABLESPACE。
数据库管理员在接收到一个创建表空间的申请时,需要从以下方面进行考量:
-
表空间所服务的业务属性:
-
HEAP表和TAC表采取段页式结构,挂载普通数据文件
CREATE TABLESPACE tablespace_name;Copied!
-
LSC表的稳态数据采取对象结构,需挂载数据桶
CREATE TABLESPACE tablespace_name DATABUCKET 'lscfile1','lscfile2';Copied!
-
对敏感数据或核心数据可定义为加密表空间
CREATE TABLESPACE tablespace_name DATABUCKET 'lscfile1','lscfile2' ENCRYPTION ENCRYPT;Copied!
-
对极高性能要求的表空间可定义为MMS表空间,同时配置MMS_DATA_LOADERS参数确定预加载策略
CREATE TABLESPACE tablespace_name MEMORY MAPPED;Copied!
-
-
表空间的存储属性:
-
确定数据文件初始值、扩展值和最大值,默认由系统自动决定
CREATE TABLESPACE yashan1 DATAFILE 'yashan1' SIZE 4M AUTOEXTEND ON NEXT 4M MAXSIZE 1G;Copied!
-
确定extent大小,默认由系统自动决定
CREATE TABLESPACE yashan1 DATAFILE 'yashan1' SIZE 4M AUTOEXTEND ON NEXT 4M MAXSIZE 1G EXTENT UNIFORM SIZE 64K;Copied!
-
对于MMS表空间,确定是否启用大页内存,启用大页内存的前提是操作系统配置大页内存
ALTER SYSTEM SET MMS_USE_LARGE_PAGES=true SCOPE=BOTH;Copied!
-
表空间运维
# offline与online
当某个表空间不再使用,或者不想被访问到时,可将其进行脱机:
ALTER TABLESPACE yashan OFFLINE;
ALTER TABLESPACE yashan OFFLINE TEMPORARY;
ALTER TABLESPACE yashan OFFLINE IMMEDIATE;
Copied!
通过online操作可以恢复被脱机的表空间:
ALTER TABLESPACE yashan ONLINE;
Copied!
# 增删数据文件
表空间可挂载的数据文件数量和数据桶数量存在规格约束(YashanDB为64),管理员需关注该限制,避免达到上限(达到上限后将无法增加数据文件,且无法通过删除数据文件的方式释放数量)。当已达到上限仍需增加数据文件或数据桶时,通过创建新的表空间来解决。
增加数据桶时还需考虑BUCKET_RESERVED_SPACE参数,该参数用于控制数据桶占用所在磁盘的空间上限。
ALTER TABLESPACE yashan ADD DATAFILE;
ALTER TABLESPACE yashan DROP DATAFILE 'yashan1';
ALTER TABLESPACE lsc_tb ADD DATABUCKET 'lscfile3','lscfile4';
ALTER TABLESPACE lsc_tb DROP DATABUCKET 'lscfile3';
Copied!
# 空闲空间回收
对单机部署和分布式部署中的表空间进行收缩,可以回收其空闲空间,供其他表空间使用。
示例(单机、分布式部署)
ALTER TABLESPACE SYSTEM SHRINK SPACE KEEP 100M;
ALTER TABLESPACE SYSTEM SHRINK SPACE;
Copied!
# 分布式表空间故障恢复
分布式部署中执行表空间DDL时出现节点故障,YashanDB提供自动恢复功能。
SELECT * FROM DV$TABLESPACE WHERE name = UPPER('tablespace名称') ORDER BY group_id;
SELECT * FROM DV$DATAFILE WHERE name LIKE '%datafile名称' ORDER BY group_id;
SELECT * FROM DV$DATABUCKET WHERE url LIKE '%bucketfile名称' ORDER BY group_id;
Copied!
Datafile,Bucketfile文件目录:
- Datafile 文件默认目录:
${YASDB_DATA}/节点名/dbfiles/ - Bucketfile 文件默认目录:
${YASDB_DATA}/节点名/local_fs/ - 如果指定了目录路径,文件目录:
${YASDB_DATA}/节点名/指定目录/
CREATE TABLESPACE
创建表空间时出现节点故障,具体情况和解决方案如下所示:
-
仅在MN节点(group_id为1)有Tablespace和Datafile或Databucket记录,DV$PUB_STAT视图没有异常Tablespace相关DDL记录,发现仅有MN节点出现故障:
-
需重启MN节点并手动在CN节点上执行如下语句:
DROP TABLESPACE IF EXISTS tablespace_name including contents AND datafiles;Copied!
-
查询
DV$TABLESPACE,DV$DATAFILE和DV$DATABUCKET视图,确认没有对应的Tablespace。 -
查询MN节点下的Datafile和Databucket文件夹,确认没有对应的Tablespace文件残留,若有则需手动清除该文件夹。
-
重启后,再次执行
CREATE TABLESPACE命令即可。
-
-
MN节点,部分CN/DN节点有Tablespace和Datafile或Databucket记录,MN节点中DV$PUB_STAT视图有异常Tablespace相关DDL推送记录,发现有部分CN/DN节点出现故障:
- 重启故障节点,等待片刻后于MN节点中查询DV$PUB_STAT视图,如没有发现异常Tablespace相关的DDL记录,则表示恢复成功;如仍查询到异常DDL记录,可通过ERR_MSG字段查看失败原因:若显示DN资源不足,则需要重新合理分配资源。
-
所有节点都没有Tablespace和Datafile或Databucket记录,MN节点中DV$PUB_STAT视图没有异常Tablespace相关DDL记录,发现仅有MN节点出现故障:
- 重启MN节点,再次执行
CREATE TABLESPACE命令即可。
- 重启MN节点,再次执行
DROP TABLESPACE
删除表空间时出现节点故障,具体情况和解决方案如下所示:
-
MN节点有Tablespace和Datafile或Databucket记录,仅有MN节点出现故障:
-
重启MN节点,并手动在CN节点上执行如下语句:
DROP TABLESPACE IF EXISTS tablespace_name including contents AND datafiles;Copied!
-
-
MN节点不存在Tablespace,CN/DN节点有Tablespace和Datafile或Databucket记录,部分CN/DN节点出现故障:
- 重启故障节点即可恢复。
ALTER TABLESPACE ADD(DATAFILE|TEMPFILE)
修改表空间数据文件时出现节点故障,具体情况和解决方案如下所示:
-
仅在MN节点(group_id为1)有Tablespace和Datafile或Databucket记录,DV$PUB_STAT视图没有异常Tablespace相关DDL记录,发现仅有MN节点出现故障:
-
需重启MN节点并手动在CN节点上执行如下语句:
ALTER TABLESPACE yashan DROP DATAFILE datafile_name;Copied!
-
查询
DV$TABLESPACE,DV$DATAFILE和DV$DATABUCKET视图,确认没有对应的Tablespace。 -
查询MN节点下的Datafile和Databucket文件夹,确认没有对应的Tablespace文件残留,若有则需手动清除该文件夹。
-
重启后,再次执行
ALTER TABLESPACE ADD(DATAFILE|TEMPFILE)命令即可。
-
-
MN节点,部分CN/DN节点有Tablespace和Datafile或Databucket记录,MN节点中DV$PUB_STAT视图有异常Tablespace相关DDL推送记录,发现有部分CN/DN节点出现故障:
- 重启故障节点,等待片刻后于MN节点中查询DV$PUB_STAT视图,如没有发现异常Tablespace相关的DDL记录,则表示恢复成功;如仍查询到异常DDL记录,可通过ERR_MSG字段查看失败原因:若显示DN资源不足,则需要重新合理分配资源。
-
所有节点都没有Tablespace和Datafile或Databucket记录,MN节点中DV$PUB_STAT视图没有异常Tablespace相关DDL记录,发现仅有MN节点出现故障:
- 重启MN节点,再次执行
ALTER TABLESPACE ADD(DATAFILE|TEMPFILE)命令即可。
- 重启MN节点,再次执行