Project Icon

llm-gateway

为OpenAI和Cohere等第三方LLM提供商设计的网关

llm-gateway是一个为OpenAI和Cohere等第三方LLM提供商设计的网关。它通过PII数据清理机制和Postgres数据库数据跟踪确保安全交互,并复刻了ChatGPT前端以保持API内通信。支持OpenAI GPT系列、Anthropic Claude系列及Meta Llama系列模型。提供便捷的API和Python调用设置,本项目使用Poetry和Pyenv进行依赖和环境管理,并支持Docker开发,适合开发者快速上手。

项目介绍:llm-gateway

🤔 什么是 llm-gateway?

llm-gateway 是一个为第三方大型语言模型(LLM)供应商如 OpenAI、Cohere 等提供的网关。它通过 PostgreSQL 数据库来追踪发送到这些供应商和从中接收的数据,并在发送前运行个人识别信息(PII)的清除策略。

根据 OpenAI 的非 API 消费者产品数据使用政策,他们可能会利用用户的输入内容、响应、上传图片和生成图片来提升服务质量,包括如 ChatGPT 和 DALL-E 等产品。使用 llm-gateway 与 OpenAI 互动是一个安全的选择。该网关还通过使用 OpenAI 的 /ChatCompletion 接口重现了 ChatGPT 前端,因此所有通信都在 API 内进行。

📦 支持的模型

以下是 llm-gateway 支持的模型列表:

供应商模型
OpenAIGPT 3.5 Turbo
OpenAIGPT 3.5 Turbo 16k
OpenAIGPT 4
AI21 LabsJurassic-2 Ultra
AI21 LabsJurassic-2 Mid
亚马逊Titan Text Lite
亚马逊Titan Text Express
亚马逊Titan Text Embeddings
AnthropicClaude 2.1
AnthropicClaude 2.0
AnthropicClaude 1.3
AnthropicClaude Instant
CohereCommand
CohereCommand Light
CohereEmbed - English
CohereEmbed - Multilingual
MetaLlama-2-13b-chat
MetaLlama-2-70b-chat

⚒️ 使用方法

使用此项目时,需要将供应商的 API 密钥保存为环境变量。如果是与 OpenAI 通信,需要设置 OPENAI_API_KEY。详细的设置步骤可通过 此链接 查看,包括 Cohere、OpenAI 和 AWS Bedrock 的详细指引。

API 使用方法

下面是与 OpenAI /completion 端点进行通信的一个示例:

curl -X 'POST' \
  'http://<host>/api/openai/completion' \
  -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -d '{
  "temperature": 0,
  "prompt": "Tell me what is the meaning of life",
  "max_tokens": 50,
  "model": "text-davinci-003"
}'

如果使用 /chat_completion 端点,可以按用户与助手对话的形式构建请求:

curl -X 'POST' \
  'http://<host>/api/openai/chat_completion' \
  -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -d '{
  "messages": [
    {"role": "assistant", "content": "You are an intelligent assistant."},
    {"role": "user", "content": "create a healthy recipe"}
  ],
  "model": "gpt-3.5-turbo",
  "temperature": 0
}'

Python 使用方法

可以通过以下 Python 代码与 OpenAI 交互:

from llm_gateway.providers.openai import OpenAIWrapper

wrapper = OpenAIWrapper()
wrapper.send_openai_request(
    "Completion",
    "create",
    max_tokens=100,
    prompt="What is the meaning of life?",
    temperature=0,
    model="text-davinci-003",
)

🚀 开发者快速入门

此项目使用 Poetry 和 Pyenv 来管理依赖和开发环境。关于这两个工具的安装可以参考 Poetry 官方文档Pyenv 官方文档。对于前端部分,该项目使用 npm 和 yarn 来管理依赖。最新的 node 版本在 .node-version 文件中有明确声明。

后端依赖

如果使用 Docker,可以选择性地省略步骤 1-3。建议安装 pre-commit 钩子以加速开发周期。

  1. 安装 Poetry 和 Pyenv
  2. 安装指定的 Python 版本:pyenv install 3.11.3
  3. 安装项目需求:
    brew install gitleaks
    poetry install
    poetry run pre-commit install
    
  4. 执行 cp .envrc.example .envrc 并更新 API 密钥

🐳 Docker 开发流程(后端和前端)

使用 Docker 运行项目:

# 启动 docker-compose
make up

# 在浏览器中打开前端
make browse

# 打开 FastAPI Swagger API
make browse-api

# 删除 docker-compose 设置
make down

通过这些操作步骤,开发者可以轻松地在 Docker 中运行和测试 llm-gateway 项目,无论是后端还是前端的开发环境。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号