sonyflake + pod hostname as machine id
- inspired by kubeflake
- build settings referenced unicode-segmenter
$ yarn add kubeflake
import { kubeflake, parse } from 'kubeflake';
const id = kubeflake(); // 509414012220366329n
parse(id);
/**
{
startTime: 2014-09-01T00:00:00.000Z,
generatedTime: 2024-04-15T06:53:32.420Z,
timestamp: 303634412420,
sequence: 0,
machineId: 24057
}
*/
... or with custom startTime
import { Kubeflake } from 'kubeflake'
const kf = new Kubeflake({
startTime: new Date('2024-04-15T00:00:00Z'),
});
const id = kf.next(); // 41628333006329n
kf.parse(id);
/**
{
startTime: 2024-04-15T00:00:00.000Z,
generatedTime: 2024-04-15T06:53:32.420Z,
timestamp: 24812420,
sequence: 0,
machineId: 24057
}
*/
$ npx kubeflake
510468309502680569n
$ npx kubeflake --parse 510468309502680569n
{
startTime: 2014-09-01T00:00:00.000Z,
generatedTime: 2024-04-22T13:27:02.570Z,
timestamp: 304262822570,
sequence: 0,
machineId: 24057
}
$ npx kubeflake --help
Usage: kubeflake [OPTIONS]
Generate 64-bit orderable unique IDs using Kubeflake.
Options:
-n, --number INTEGER Number of Kubeflake IDs to generate (default is 1).
Please provide a positive integer value.
-p, --parse STRING Parse a Kubeflake ID and display its components in JSON format.
Only valid formats that can be parsed into a BigInt are accepted.
-h, --help Show this message and exit.