Skip to content

Latest commit

 

History

History
40 lines (24 loc) · 1.82 KB

README.md

File metadata and controls

40 lines (24 loc) · 1.82 KB

Elasticflake

Sequential UUID / Flake ID generator pulled out of elasticsearch common

This library is 100% verbatim copy and paste from elasticsearch common and was 30 mins to package into a lib. All credit should go to:

And I'm sure many others...

Why

Elasticsearch is a large dep to pull in just to get sequential uuids. If you already have elasticsearch as a dependency, you are better off using it the UUID generator from there. However, if you are generating time series data that may eventually live in elasticsearch (or any other datastore with primary key support), it is a best practice to generate the UUID as soon as possible in the pipeline.

Preventing duplicates

If you are generating time series data that doesn't have a natural primary key, you want to make sure that if there are hiccups throughout the system a unique UUID at message creation can give once and only once messaging guarantees. This is especially useful if using Kafka, RabbitMQ, or other messaging systems for guaranteed delivery.

Performance

Random UUIDs are not good for primary key/clustered index as they cause lots of page splits and overheads. Time based UUIDs alleviate these problems for both SQL and elasticsearch based indexes.

Building

Clone the repo and run

gradle publishToMavenLocal

Once published to your local Maven you can pick up from any other project, eg from sbt:

"org.limberware" % "elasticflake" % "0.1-SNAPSHOT"

If someone finds this useful, open a pull request to get published to Maven central and I can version and make that happen.