You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@impala.apache.org by "Quanlong Huang (Jira)" <ji...@apache.org> on 2022/04/24 08:26:00 UTC

[jira] [Created] (IMPALA-11265) Iceberg tables have a large memory footprint in catalog cache

Quanlong Huang created IMPALA-11265:
---------------------------------------

             Summary: Iceberg tables have a large memory footprint in catalog cache
                 Key: IMPALA-11265
                 URL: https://issues.apache.org/jira/browse/IMPALA-11265
             Project: IMPALA
          Issue Type: Improvement
          Components: Catalog
            Reporter: Quanlong Huang


During the investigation of IMPALA-11260, I found the cache item size of a (IcebergApiTableCacheKey, org.apache.iceberg.BaseTable) pair could be 30MB.

For instance, here are the cache items of the iceberg table {{{}functional_parquet.iceberg_partitioned{}}}:
{code:java}
weigh=3792, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$TableCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$TableMetaRefImpl
weigh=14960, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$IcebergMetaCacheKey, valueClass=class org.apache.impala.thrift.TPartialTableInfo
weigh=30546992, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$IcebergApiTableCacheKey, valueClass=class org.apache.iceberg.BaseTable
weigh=496, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=496, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=496, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=512, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=472, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionListCacheKey, valueClass=class java.util.ArrayList
weigh=10328, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl{code}
Note that this table just have 20 rows. The total memory footprint size is 30MB.

For a normal partitioned partquet table, the memory footprint is not that large. For instance, here are the cache items for {{{}functional_parquet.alltypes{}}}:
{code:java}
weigh=4216, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$TableCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$TableMetaRefImpl
weigh=480, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=472, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=480, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=488, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=496, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=352, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=352, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$ColStatsCacheKey, valueClass=class org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj
weigh=4248, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionListCacheKey, valueClass=class java.util.ArrayList
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1296, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl
weigh=1288, keyClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionCacheKey, valueClass=class org.apache.impala.catalog.local.CatalogdMetaProvider$PartitionMetadataImpl{code}
The total size is around 45KB.

It worths double checking whether we need the whole org.apache.iceberg.BaseTable object. Maybe we can just extract what Impala needs into a custom value class.

CC [~boroknagyz] 



--
This message was sent by Atlassian Jira
(v8.20.7#820007)