kylin的查询的时候,如果查询的维度在同一个聚合组,kylin会直接去HBase取到预计算的值,如过查询的维度不在同一个维度组,kylin会根据进行实时计算,这个过程类似build过程中的计算,并且会在monitor上使用slow query记录这些需要实时计算的sql,我们可以根据slow query来进行维度组的优化。
第一个问题:
在Tableau中显示的度量值如果是SUM计算,那么在Hive中最好使用的字段类型为decimal(20,0),避免使用int以及bigint。
第二个问题:
高基数维度的Cube在构建过程中报错
GC limite exceeded 以及 java.lang.OutOfMemoryError: Java heap space
解决办法:在${KYLIN_HOME}/conf/kylin_job_conf.xml中添加配置项如下:
<property>
<name>mapreduce.map.java.opts.max.heap</name>
<value>983</value>
</property>
<property>
<name>mapreduce.reduce.java.opts.max.heap</name>
<value>983</value>
</property>
<property>
<name>mapreduce.map.java.opts</name>
<value>-Xmx8000m -XX:OnOutOfMemoryError='kill -9 %p'</value>
<description></description>
</property>
<property>
<

Apache Kylin在处理高基数维度时可能会遇到性能挑战,包括实时计算消耗大、内存溢出等问题。解决方案包括调整Hive字段类型为decimal,配置`kylin_job_conf.xml`以应对`GC limit exceeded`和`OutOfMemory`错误,优化维度组策略,将高基数维度置于RowKey前列并启用sharding,以及对count distinct操作进行专门的ColumnFamily设置。此外,通过设置维度字段同时作为度量,可以实现更灵活的查询需求。
最低0.47元/天 解锁文章
1572

被折叠的 条评论
为什么被折叠?



