The historic data loader (hereinafter termed 'HDL') is a tool for bulk loading UC exports.
The process uses HBases's bulk loading capabilities which utilise map-reduce to prepare HFiles directly, hbase is then directed to adopt these files. A useful post on this technique can be found here.
Each run of HDL should process files all destined for the same table, so many runs of HDL are needed to perform a full import of each table's historic data - one for each table in HBase. This is a requirement of the HBases incremental load feature which this application uses.
The application can only run on EMR. Until we have a licence for localstack pro (which provides EMR), testing will be performed by the end to end tests.
Build the jar
gradle build
Transfer the jar to s3 (replace the words development-bucket
with and actual writable bucket in 33.)
aws --profile dataworks-development s3 cp ./build/libs/historic-data-loader-1.0-SNAPSHOT-all.jar s3://development-bucket/
Transfer the script to run the jar to the same bucket (one time activity)
aws --profile dataworks-development s3 cp ./resources/scripts/run.sh s3://development-bucket/
Log onto to the hbase master
aws ssm ....
Fetch the jar and the script
aws --profile dataworks-development s3 cp s3://development-bucket/historic-data-loader-1.0-SNAPSHOT-all.jar .
aws --profile dataworks-development s3 cp s3://development-bucket/run.sh .
Create a table to load into (must match the table name specified in the script)
hbase shell
> create table 'agent_core:agentToDo', { NAME => 'cf', VERSIONS => 100 }
.. or truncate an existing table
> truncate 'agent_core:agentToDo'
.. or do nothing and use an existing table.
Kick off the job
./run.sh
The script is very rough and ready and only for kicking off dev runs, alter the exported environment variables therein to suit your needs.
Check the logs
First you need to get the application Id which looks something like this application_1601048545520_0023
, look for the
line like this on the console after the run:
20/10/01 08:45:43 INFO impl.YarnClientImpl: Submitted application application_1601048545520_0023
Then to see the logs:
yarn logs --applicationId <id-determined-above>
Name | Purpose | Default value | Notes |
---|---|---|---|
AWS_REGION | Location of infrastructure | eu-west-2 | Default probably suitable for deployed instances |
AWS_USE_LOCALSTACK | Indicates whether the code is running in localstack environment (for integration tests) | false | Can use default for deployed instances |
HBASE_TABLE | The table to which the data should be written | data | Needs to target a single table for each run and so to some extent needs to be ably to be set dynamically by whatever initiates a load. |
MAP_REDUCE_OUTPUT_DIRECTORY | Where the Hfiles should be written to and from where HBase will pick them up when it is directed to adopt them | /user/hadoop/bulk | Will need to be set for uniquely each topic, and not be an existing directory in hdfs |
S3_BUCKET | The bucket containing the objects of previously streamed records | corporatestorage | Will need to be set explicitly for aws deployed instances. |
S3_MAX_CONNECTIONS | How many concurrent s3 connections to allow | 1000 | Default probably ok. |
S3_PREFIX | The path to the files to be restored | data | Should be one tables worth of data. |
TOPIC_NAME | The name of the topic whose files are being reloaded | This is needed to filter the s3 object list down to 1 topics worth of files |