故笙诉离歌  发表于 2020-5-28 13:55 显示全部楼层 楼主
使用系统表information_schema.cluster_tables统计表占用空间大小

一个人的天空  发表于 2020-5-28 15:04 显示全部楼层 沙发
通过information_schema.cluster_tables表的TABLE_DATA_SIZE和TABLE_STORAGE_SIZE字段进行统计。
TABLE_DATA_SIZE是数据存储空间(主备分片之和);
TABLE_STORAGE_SIZE是数据存储空间+元数据存储空间(主备分片之和)
   
以本地虚拟机2节点集群p 2 d 1配置为例,创建hash分布表test:
CREATE TABLE "test" ("a" int(11) DEFAULT NULL) DISTRIBUTED BY('a'); 插入数据并翻倍到83886080条记录。
gbase> select TABLE_NAME,TABLE_DATA_SIZE,TABLE_STORAGE_SIZE from information_schema.cluster_tables where table_schema='lz' and table_name='test';
+------------+-----------------+--------------------+
| TABLE_NAME | TABLE_DATA_SIZE | TABLE_STORAGE_SIZE |
+------------+-----------------+--------------------+
| test       |         1571972 |            1846824 |
+------------+-----------------+--------------------+
   
1)TABLE_DATA_SIZE 计算   
[gbase@node1 test_n2]$ pwd
/opt/gnode/userdata/gbase/lz/sys_tablespace/test_n2
[gbase@node1 test_n1]$ du -csb *
104428 C00000.seg
209177 C00000.seg.1
313605 total
[gbase@node1 test_n1]$ cd ../test_n2/
[gbase@node1 test_n2]$ du -csb *
157454 C00000.seg
314927 C00000.seg.1
472381 total
(313605+472381)*2=1571972(TABLE_DATA_SIZE)
2)TABLE_STORAGE_SIZE 计算
再计算元数据空间
[gbase@node1 test_n1.GED]$ pwd
/opt/gnode/userdata/gbase/lz/metadata/test_n1.GED
[gbase@node1 test_n1.GED]$ du -csb *
128 C00000.ctl.A
128 C00000.ctl.B
54325 C00000.map
230 table.des.A
230 table.des.B
52 table.state.A
52 table.state.B
55145 total
[gbase@node1 test_n1.GED]$ cd ../test_n2.GED/
[gbase@node1 test_n2.GED]$ du -csb *
128 C00000.ctl.A
128 C00000.ctl.B
81461 C00000.map
230 table.des.A
230 table.des.B
52 table.state.A
52 table.state.B
82281 total
(55145 + 82281)*2 + 1571972(TABLE_DATA_SIZE)=1846824 (TABLE_STORAGE_SIZE)
复制表的计算方式也一样。

您需要登录后才可以回帖 登录 | 立即注册