逆向Pieces-OS GRPC流并转换为标准OpenAI接口的项目
所有模型均由 Pieces-OS 提供
本项目基于GPLV3协议开源
如果帮助到了你,能否给一个Star呢?
本项目仅供学习交流使用,不得用于商业用途,如有侵权请联系删除
请善待公共服务,尽量自己搭建(不要搞黄,demo会崩溃)
HuggingFace API_PREFIX环境变量为/hf
复制huggingface空间 注意事项 抱脸会阻止/v1的请求,设置API_PREFIX为/hf或任意/+其他字母或数字组合即可,使用时在原先的请求点上添加即可,例如https://xxx.hf.space/v1/models变成https://xxx.hf.space/hf/v1/models 如果不能复制空间,就把原空间文件全部下载,新建一个public空间,删除之前的并重新上传并重启即可
请注意下列环境变量!私人使用请添加API_KEY!
cloudflare work反代koyeb
export default {
async fetch(request, env) {
// 创建目标 URL 改成你自己的部署地址,不带协议头和/
const url = new URL(request.url);
url.hostname = 'abcdefg.koyeb.app';
// 创建新的请求对象
const newRequest = new Request(url, {
method: request.method,
headers: request.headers,
body: request.method === 'POST' ? request.body : null,
redirect: 'follow'
});
// 转发请求并返回响应
return fetch(newRequest);
}
}
- 流式实现
- Serverless部署
- Docker支持
- 静态Proto JS
api
index.js Node.js的项目文件,即开即用
protos
GPTInferenceService.proto # GPT的GRPC定义
VertexInferenceService.proto # 其余几乎所有模型的GRPC定义
cloud_model.json 云端模型的配置文件,请提取unique中的模型使用
package.json 项目依赖
vercel.json Vercel部署配置文件
healthCheck.js 用于自动重启崩溃的主程序
- claude-3-5-sonnet@20240620
- claude-3-haiku@20240307
- claude-3-sonnet@20240229
- claude-3-opus@20240229
- gpt-3.5-turbo
- gpt-4
- gpt-4-turbo
- gpt-4o-mini
- gpt-4o
- gemini-pro
- gemini-1.5-flash
- gemini-1.5-pro
- chat-bison
- codechat-bison
安装 package.json 中定义的依赖库后,执行 node index.js 启动程序。若需要自动重启功能,请额外执行 node healthCheck.js
获取模型
curl --request GET 'http://127.0.0.1:8787/v1/models' \
--header 'Content-Type: application/json'
请求
curl --request POST 'http://127.0.0.1:8787/v1/chat/completions' \
--header 'Content-Type: application/json' \
--header "Authorization: Bearer Your API_KEY" \
--data '{
"messages": [
{
"role": "user",
"content": "你好!"
}
],
"model": "gpt-4o",
"stream": true
}'
- 描述: API 请求的前缀路径。
- 默认值:
'/'
- 获取方式:
process.env.API_PREFIX || '/'
- 描述: API 请求的密钥。
- 默认值: 无
''
- 获取方式:
process.env.API_KEY || ''
- 描述: 最大重试次数。
- 默认值:
3
- 获取方式:
process.env.MAX_RETRY_COUNT || 3
- 描述: 重试延迟时间,单位为毫秒。
- 默认值:
5000
(5秒) - 获取方式:
process.env.RETRY_DELAY || 5000
- 描述: 服务监听的端口。
- 默认值:
8787
- 获取方式:
process.env.PORT || 8787
- 描述: 服务监听的端口。
- 默认值: 所有模型
- 获取方式: `process.env.SUPPORTED_MODELS
- 描述: 健康(index.js状态)检查的时间间隔,以秒为单位。
- 默认值:
60
秒 - 获取方式:
process.env.CHECK_INTERVAL
非本人维护,docker_test分支含最新更改,未经验证
x86架构请拉取chb2024/pieces-os:latest
,arm架构请拉取chb2024/pieces-os-arm:latest
docker对于2.0.0以上的版本支持自动重启
以下为x86架构部署示例,arm用户更换镜像即可
- 下载
docker-compose.yml
文件:
curl -sSL https://raw.githubusercontent.com/Nekohy/pieces-os/main/docker-compose.yml
-
修改配置:
- 将
API_KEY=sk-123456
中的值修改为您自定义的密钥,用于保护部署的项目 - 如需要,可以修改左侧端口号(默认8787)
- 将
-
启动服务:
docker-compose up -d
- 停止服务:
docker-compose down
如果您不想使用 Docker Compose,也可以直接使用 Docker 命令:
- 拉取镜像:
docker pull chb2024/pieces-os:latest
- 运行容器:
docker run -d \
--name pieces-os \
-p 8787:8787 \
-e API_KEY=sk-123456 \
--restart unless-stopped \
chb2024/pieces-os:latest
curl -sSL https://raw.githubusercontent.com/Nekohy/pieces-os/main/install.sh | sudo bash
根据提示输入即可
注意事项:
- 可以修改
API_KEY
用于保护您部署的docker - 可以修改端口映射的左侧数值(如
-p 9000:8787
) - 右侧端口(8787)和其他默认配置请勿修改
- 管理容器:
## 停止容器
docker stop pieces-os
## 启动容器
docker start pieces-os
## 重启容器
docker restart pieces-os
## 删除容器
docker rm pieces-os
请确保在使用服务时使用正确的 API_KEY 进行认证。