You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@hudi.apache.org by "wl (Jira)" <ji...@apache.org> on 2022/09/09 17:19:00 UTC

[jira] [Created] (HUDI-4824) add new index RANGE_BUCKET , when primary key is auto-increment like most mysql table

wl created HUDI-4824:
------------------------

             Summary: add new index RANGE_BUCKET , when primary key is auto-increment like most mysql table
                 Key: HUDI-4824
                 URL: https://issues.apache.org/jira/browse/HUDI-4824
             Project: Apache Hudi
          Issue Type: New Feature
            Reporter: wl


h3. Change Logs

Usually, in the mysql... table, there is an auto-increment primary key, base this fact and Bucket index , we propose a Range_Bucket index. And get a good performence in my practice.

Base concept is like Bucket index, and most important is: bucketId = primaryKey / stepSize
For example, if set stepSize = 2
bucketId Mapping will like this:
pKey, bucketId
1, 0
2, 0
3, 1
4, 1
5, 2
6, 2
7, 3
...

In my practice, I sync about 1000+ mysql table to hudi, and I set setpSize = 1,500,000, and basefile size will be about 50m - 350m.

Test like this, is set stepSize = 2 and pKey = \{1, 4, 9}, will get three base file:
[!https://user-images.githubusercontent.com/67826098/189126613-a50e3347-900f-4477-a4e8-f935bd996ebd.png|width=762!|https://user-images.githubusercontent.com/67826098/189126613-a50e3347-900f-4477-a4e8-f935bd996ebd.png]
h3. Impact

Introduce a new index RANGE_BUCKET, people can ust it like following:
 {{  option(HoodieIndexConfig.INDEX_TYPE.key, IndexType.BUCKET.name()).
  option(HoodieIndexConfig.BUCKET_INDEX_ENGINE_TYPE.key, "RANGE_BUCKET").
  option(HoodieIndexConfig.RANGE_BUCKET_STEP_SIZE.key, 2).
  option(HoodieLayoutConfig.LAYOUT_TYPE.key, "BUCKET").
  option(HoodieLayoutConfig.LAYOUT_PARTITIONER_CLASS_NAME.key, classOf[SparkRangeBucketIndexPartitioner[_]].getName).}}
*Risk level: none | low | medium | high*

low



--
This message was sent by Atlassian Jira
(v8.20.10#820010)