[ 
https://issues.apache.org/jira/browse/PHOENIX-3000?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Lars Hofhansl updated PHOENIX-3000:
-----------------------------------
    Attachment: 3000.txt

Here's a simple fix. Copy the key, unless it occupies more than 10% of the 
array handed to us. Or in other words, if we can save 90% of HEAP during 
aggregate we'll take the hit of making the copy.

In some tests I ran that made the difference between finishing and simply 
running out of memory.

Note that it is not quite as simple. If the block is cached in HBase anyway - 
and we're not using BLOCK_ENCODING - we would not consume more memory since we 
made a copy, but the block is on the heap anyway.


> Reduce memory consumption during DISTINCT aggregation
> -----------------------------------------------------
>
>                 Key: PHOENIX-3000
>                 URL: https://issues.apache.org/jira/browse/PHOENIX-3000
>             Project: Phoenix
>          Issue Type: Bug
>            Reporter: Lars Hofhansl
>         Attachments: 3000.txt
>
>
> In {{DistinctValueWithCountServerAggregator.aggregate}} we hold on the ptr 
> handed to us from HBase.
> Note that this pointer points into an HFile Block, and hence we hold onto the 
> entire block for the duration of the aggregation.
> If the column has high cardinality we might attempt holding the entire table 
> in memory in the extreme case.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to