- # ❄ 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(与计算能力有关)
-
- snowdrift.Multi=0 //是否支持多WorkerId,0:不支持(可用WorkerId=snowdrift.WorkerId),1:支持(可用WorkerId=1~(2^WorkerIdBitLength-1)),默认0
- ```
-
- **函数签名**:
- ```php
- \SnowDrift::NextId(int $wid=snowdrift.WorkerId):?int //获取单个id,$wid可选,默认值=snowdrift.WorkerId,snowdrift.Multi=0情况下会忽略此参数
- \SnowDrift::NextNumId(int $num, int $wid=snowdrift.WorkerId):?array //获取$num个id,$wid可选,默认值=snowdrift.WorkerId,snowdrift.Multi=0情况下会忽略此参数
- ```
-
- **调用示例**
- ```php
- $id=\SnowDrift::NextId();
- $id=\SnowDrift::NextId(3);
-
- $ids=\SnowDrift::NextNumId(10000);
- $ids=\SnowDrift::NextNumId(10000,3);
- ```
|