chivincent / snowflake
Twitter Snowflake for PHP implementation.
Installs: 1 609
Dependents: 0
Suggesters: 0
Security: 0
Stars: 12
Watchers: 1
Forks: 1
pkg:composer/chivincent/snowflake
Requires
- php: >= 7.1.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.10
- phpunit/phpunit: ^7.0
This package is not auto-updated.
Last update: 2020-08-22 07:13:10 UTC
README
Twitter Snowflake for PHP implementation.
Installation
composer require chivincent/snowflake
Usage
<?php require __DIR__ . '/vendor/autoload.php'; use Chivincent\Snowflake\Snowflake; $snowflake = new Snowflake(); // Generate single unique ID. $snowflake(); // It will return int. $snowflake->gen(); // It will return an array with single element. // Generate 10 unique IDs $snowflake->gen(10); // Generate 1000 unique IDs $snowflake->gen(1000);
Description
How's the return value?
It is an array contains 1 or more 64 bits integer, which can be store in MySQL as bigint data type.
How's it can be "UNIQUE" in the same request?
The value is generated by millisecond, machine id and sequence number.
When use it on more then one machine , you should set MACHINE_ID(0 ~ 8191) as your local environment.
In the same millisecond, it will use Sequence for promising the value is unique.
How's the data store in the 64 bits number? (By default)
+---------------------------------+----------------------+-------------------+
| millisecond timestamp (41 bits) | machine id (13 bits) | sequence (9 bits) |
+---------------------------------+----------------------+-------------------+
You can reset this data storage for machine id and sequence when construct Chivincent\Snowflake\Snowflake
<?php require __DIR__ . '/vendor/autoload.php'; use Chivincent\Snowflake\Snowflake; use Chivincent\Snowflake\StaticSequence; $snowflake = new Snowflake(StaticSequence::class, 14, 8); // The machine id length is 14 bits. // The sequence length is 8 bits. // Note: The sum of machine id length and sequence length should be 22.
Is it possible repeat?
Unfortunately, it is possible.
This package is using static variable for controlling sequence, but it could be repeat in different requests.
How to resolve race condition?
Make a sequence class which implements Chivincent\Snowflake\Sequencer interface, you can define the static method next for generating sequence by redis or memcached.
Example:
<?php namespace MyAwesome\Project; use Chivincent\Snowflake\Sequencer; class RedisSequence implements Sequencer { protected $redis; public static function next(int $timestamp): int { if (!$redis->timestampExists($timestamp)) { $redis->insertCurrentTimestamp($timestamp); return 0; } if ($redis->isLimit()) { return self::WAIT_FOR_NEXT_TIME; } return $redis->getNextNumber(); } } // Use your RedisSequence when Snowflake's constructor. new Snowflake(RedisSequence::class);
LICENSE
This library is under MIT LICENSE.