50 lines
1.9 KiB
Markdown
50 lines
1.9 KiB
Markdown
# ❄ idgenerator-php-extension
|
||
|
||
## 介绍
|
||
项目更多介绍参照:https://github.com/yitter/idgenerator
|
||
|
||
## PHP环境
|
||
|
||
* PHP7 or later
|
||
|
||
## 安装方式
|
||
|
||
```shell
|
||
git clone https://github.com/yitter/idgenerator.git
|
||
cd idgenerator/PHP
|
||
phpize
|
||
./configure --with-php-config=/path/php-config
|
||
make
|
||
make install
|
||
```
|
||
|
||
## 如何使用(PHP)
|
||
|
||
**配置文件配置参数**:
|
||
```shell
|
||
//snowdrift.ini
|
||
snowdrift.Method=1 // 雪花计算方法,(1-漂移算法|2-传统算法),默认1
|
||
snowdrift.BaseTime=1582136402000 //基础时间(ms单位),不能超过当前系统时间
|
||
snowdrift.WorkerId=1 //机器码,必须由外部设定,最大值 2^WorkerIdBitLength-1
|
||
snowdrift.WorkerIdBitLength=6 //机器码位长,默认值6,取值范围 [1, 15](要求:序列数位长+机器码位长不超过22)
|
||
snowdrift.SeqBitLength=6 //序列数位长,默认值6,取值范围 [3, 21](要求:序列数位长+机器码位长不超过22)
|
||
snowdrift.MaxSeqNumber=0 //最大序列数(含),设置范围 [MinSeqNumber, 2^SeqBitLength-1],默认值0,表示最大序列数取最大值(2^SeqBitLength-1]
|
||
snowdrift.MinSeqNumber=5 //最小序列数(含),默认值5,取值范围 [5, MaxSeqNumber],每毫秒的前5个序列数对应编号0-4是保留位,其中1-4是时间回拨相应预留位,0是手工新值预留位
|
||
snowdrift.TopOverCostCount=2000 //最大漂移次数(含),默认2000,推荐范围 500-20000(与计算能力有关)
|
||
```
|
||
|
||
**函数签名**:
|
||
```php
|
||
\SnowDrift::NextId(int $wid=snowdrift.WorkerId):?int //获取单个id,$wid可选,默认值=snowdrift.WorkerId
|
||
\SnowDrift::NextNumId(int $num, int $wid=snowdrift.WorkerId):?array //获取$num个id,$wid可选,默认值=snowdrift.WorkerId
|
||
```
|
||
|
||
**调用示例**
|
||
```php
|
||
$id=\SnowDrift::NextId();
|
||
$id=\SnowDrift::NextId(3);
|
||
|
||
$ids=\SnowDrift::NextNumId(10000);
|
||
$ids=\SnowDrift::NextNumId(10000,3);
|
||
```
|