本项目为 Snowflake 算法在 gRPC 中的实现,server 采用 Golang 编写,示例 client 采用 PHP 编写(client/
)。
macOS/Linux 执行
./build.sh
Windows 执行:
./build.bat
编译后的可执行程序将会输出到 bin/
在可执行程序同一目录一下保存一份名为 config.json
的配置文件,示例:
{
"server": "127.0.0.1",
"nodeId": 1,
"port": 6666
}
也可以直接复制 config.json.example
到 bin/
并改名为 config.json
cd bin
./snowflake-grpc-server
# 拉取镜像
docker pull mryian/snowflake-grpc-server:latest
# 启动容器
docker run --restart=always -d --name snowflake -p 6666:6666 mryian/snowflake-grpc-server:latest
# 或者
docker run --restart=always -d --name snowflake -v ./config.json:/config.json -p 6666:6666 mryian/snowflake-grpc-server:latest
通过 composer 安装依赖和编译自动加载
cd client
composer install && composer dumpautoload
因为 protobuf 的 PHP 扩展截止目前(2018.06.21)还不支持 Windows,如果是 Windows 下运行,则还需要用 composer 安装 protobuf 依赖:
composer require google/protobuf
php client.php