Skip to content
forked from Nekohy/pieces-os

逆向Pieces-OS GRPC流并转换为标准OpenAI接口的项目

License

Notifications You must be signed in to change notification settings

Dr-jw/pieces-os

 
 

Repository files navigation

项目简介

img

逆向Pieces-OS GRPC流并转换为标准OpenAI接口的项目

所有模型均由 Pieces-OS 提供

本项目基于GPLV3协议开源

如果帮助到了你,能否给一个Star呢?

免责声明

本项目仅供学习交流使用,不得用于商业用途,如有侵权请联系删除

DEMO站

请善待公共服务,尽量自己搭建(不要搞黄,demo会崩溃)

Vercel

Cloudflare worker反代koyeb

HuggingFace API_PREFIX环境变量为/hf

一键部署

Vercel部署后若修改参数请记得重新Redeploy

Deploy on Vercel

Deploy to Koyeb

复制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);
  }
}

todo

  • 流式实现
  • 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部署配置文件

测试可用模型

Claude 系列(Nextchat可将@换为-)

  • claude-3-5-sonnet@20240620
  • claude-3-haiku@20240307
  • claude-3-sonnet@20240229
  • claude-3-opus@20240229

GPT 系列

  • gpt-3.5-turbo
  • gpt-4
  • gpt-4-turbo
  • gpt-4o-mini
  • gpt-4o

Gemini 系列

  • gemini-pro
  • gemini-1.5-flash
  • gemini-1.5-pro

其他

  • chat-bison
  • codechat-bison

手动部署

安装 package.json 中定义的依赖库后,执行 node index.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_PREFIX

  • 描述: API 请求的前缀路径。
  • 默认值: '/'
  • 获取方式: process.env.API_PREFIX || '/'

API_KEY

  • 描述: API 请求的密钥。
  • 默认值: 无 ''
  • 获取方式: process.env.API_KEY || ''

MAX_RETRY_COUNT

  • 描述: 最大重试次数。
  • 默认值: 3
  • 获取方式: process.env.MAX_RETRY_COUNT || 3

RETRY_DELAY

  • 描述: 重试延迟时间,单位为毫秒。
  • 默认值: 5000(5秒)
  • 获取方式: process.env.RETRY_DELAY || 5000

PORT

  • 描述: 服务监听的端口。
  • 默认值: 8787
  • 获取方式: process.env.PORT || 8787

SUPPORTED_MODELS

  • 描述: 服务监听的端口。
  • 默认值: 所有模型
  • 获取方式: `process.env.SUPPORTED_MODELS

Docker 部署说明

非本人维护,docker_test分支含最新更改,未经验证

使用 Docker Compose(推荐)

  1. 下载 docker-compose.yml 文件:
curl -sSL https://raw.githubusercontent.com/Nekohy/pieces-os/main/docker-compose.yml
  1. 修改配置:

    • API_KEY=sk-123456 中的值修改为您自定义的密钥,用于保护部署的项目
    • 如需要,可以修改左侧端口号(默认8787)
  2. 启动服务:

docker-compose up -d
  1. 停止服务:
docker-compose down

使用 Docker 命令

如果您不想使用 Docker Compose,也可以直接使用 Docker 命令:

  1. 拉取镜像:
docker pull chb2024/pieces-os:latest
  1. 运行容器:
docker run -d \
  --name pieces-os \
  -p 8787:8787 \
  -e API_KEY=sk-123456 \
  --restart unless-stopped \
  chb2024/pieces-os:latest

一键安装脚本(docker+本项目),适用于Ubuntu,Debian......

curl -sSL https://raw.githubusercontent.com/Nekohy/pieces-os/main/install.sh | sudo bash

根据提示输入即可

注意事项:

  • 可以修改 API_KEY 用于保护您部署的docker
  • 可以修改端口映射的左侧数值(如 -p 9000:8787
  • 右侧端口(8787)和其他默认配置请勿修改
  1. 管理容器:
## 停止容器
docker stop pieces-os

## 启动容器
docker start pieces-os

## 重启容器
docker restart pieces-os

## 删除容器
docker rm pieces-os

请确保在使用服务时使用正确的 API_KEY 进行认证。

About

逆向Pieces-OS GRPC流并转换为标准OpenAI接口的项目

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 70.9%
  • Shell 27.1%
  • Dockerfile 2.0%