I have little app that i plan to run behind load balancer, with up to 5-8 instances.
Inside the app has service, that needs to generate unique number that has up to 10 digits ( so 1-10 digits) each time user triggers the process.
There will be approximately 10-50k invocations of this function per month.
In non-distributed environment i was using DB's sequence to generate another unique number. I can still use this as central generator of numbers, however it would introduce single point of failure + it would be slower since every instance of my app would be getting number from single sequence ( but speed is not really issue ).
I was researching ways of generating unique numbers in distributed environment and found out about Twitter snowflake.
Since it includes timestamp it is possible to order the numbers by time which is plus.
However this is 64 bit number so it would be up for 20 digit number - i need maximum 10 thus i need log2(9999999999) + 1 bits = 34. Right now i have plan to have maximum 8 instances =  4 bits,
If i approximate 50k calls (as upper bound ) per month, include 3 years support, thats 50k*12*3 thats 1800000 calls divided by 8 ( number of instances ) and thats 225000, that is represented by 18 bits.
So i am left with
|12bits|4bits|18 bits|
Even if i set custom epoch time, i really cant save much milliseconds in 12 bits, thus this technique is not really usable for 34 bit number.
If i omit the timestamp part, and give up on ability to sort by time i can use
|_____4 bits for encoding node _____ |30 bits to encode number| which would give me much more space for sequence, and some space to include more nodes ( and use more than 4 bits for encoding it ).
However, what if i would need ability to sort? Is there any technique i have not found? Or what is "standard" ( or one of the standard ways ) to do so ?
Thanks for help! All links/techniques and everything that will send me down the rabbit hole much appreciated. Also, whe does the twitter snowflake needs leading 0 ? Cant they just assume Unsigned number?

