|Other names||Twitter Snowflake|
Snowflake IDs, or snowflakes, are a form of unique identifier used in distributed computing. The format was created by Twitter and is used for the IDs of tweets. The format has been adopted by other companies, including Discord, and Instagram, which uses a modified version.
Snowflakes are 64 bits. (Only 63 are used to fit in a signed integer.) The first 41 bits are a timestamp, representing milliseconds since the chosen epoch. The next 10 bits represent a machine ID, preventing clashes. Twelve more bits represent a per-machine sequence number, to allow creation of multiple snowflakes in the same millisecond.
Snowflakes are sortable by time, because they are based on the time they were created. Additionally, the time a snowflake was created can be calculated from the snowflake. This can be used to get snowflakes (and their associated objects) that were created before or after a particular date.
The format was first announced by Twitter in June 2010. Due to implementation challenges, they waited until later in the year to roll out the update. Twitter uses snowflake IDs for tweets, direct messages, users, lists, and all other objects available over the API.
Discord also uses snowflakes, with their epoch set to the first second of the year 2015.
- "twitter-archive/snowflake at b3f6a3c6ca". October 1, 2012. Retrieved January 18, 2021.
- "API Reference". Discord Developer Portal. Discord. Retrieved January 18, 2021.
- King, Ryan (June 1, 2010). "Announcing Snowflake". blog.twitter.com. Twitter. Retrieved January 18, 2021.
- Siegler, MG (October 12, 2010). "Tweet IDs About To Get Jumbled In A Blizzard As Snowflake Is Set To Roll Live". TechCrunch. Retrieved January 18, 2021.
- "Twitter IDs". Twitter Developer. Twitter. Retrieved January 20, 2021.
- "Sharding & IDs at Instagram". Instagram Engineering. May 2, 2016. Retrieved January 18, 2021.