openai api代理服务搭建

简介

搭建代理服务是解决网络限制,可以通过代理服务间接使用chatgpt,当然如果你能直接使用chatgpt,肯定比使用代理服务来得好,chatgpt的回答是比api的回答要更加精准。搭建代理服务器的场景可以用于给公司内部同事使用,或者自己做个小程序付费用户使用。

之前是通过api接口调用的方式调用openai的api,这种调用的弊端就是必须要等回答全部返回之后,才能传递给前端,这个过程会因为回答的长度而变得响应时间很长,体验较差。也说接口加stream参数,可以流式返回,尝试过,没有成功。

而后来openai写了一个openai的python库(为什么不出java的sdk版本,之前api调用是java实现的,这次还得切到python),封装了api请求的操作,可以很丝滑的进行api请求和流式返回。废话不多说,先在来说代理服务搭建和相关代码。

当然还得有一个前提:开发者得有一个chatgpt账号,拿到api_key,一台可以"上网"的代理服务器

搭建

这次主要说后端服务,采用了flask的web框架(轻便),整个项目就main.py

python 复制代码
from flask import Flask, Response, request
from openai import OpenAI

app = Flask(__name__)

PROXY_URL = 'PROXY_URL'

API_KEY = 'API_KEY'


def generate_stream(data, token):
    # 模型
    model = data.get('model', 'gpt-3.5-turbo')
    # 消息,需要把会话历史全部带上
    messages = data.get('messages', [])
    if not messages or not token:
        return ''
    print('model:', model)
    print('messages:', messages)
    client = OpenAI(api_key=API_KEY, base_url=PROXY_URL)
    # 确保stream=True以启用响应流处理
    stream = client.chat.completions.create(
        model=model,
        messages=messages,
        stream=True,
    )

    for chunk in stream:
        if chunk.choices[0].delta.content is not None:
            # 流式返回
            print(chunk.choices[0].delta.content, end="---")
            yield chunk.choices[0].delta.content


@app.route('/aiproxy/openai/stream', methods=['POST'])
def get_stream():
    print("----请求记录----")
    data = request.get_json()
    token = request.headers.get('Authorization')
    return Response(generate_stream(data, token), mimetype='text/event-stream', content_type='text/event-stream')


if __name__ == '__main__':
    # 启动web程序,监听5000端口
    app.run(host='0.0.0.0', port=5000, debug=True)

requirements(不是都用上了)

bash 复制代码
Flask==3.0.1
openai==1.12.0
PyMySQL==1.0.2
requests==2.28.2
SQLAlchemy==2.0.3
urllib3==1.25.11
pip==21.3.1
pandas==2.0.1

我在代理服务器上装了nginx,通过nginx的正向代理转发到openai,所以PROXY_URL要填ip+port/v1。

总结

以上就是最简单的代理请求的代码,真的要运行起来,还需要nginx的搭建,前端服务,另外后端还需要会话历史的保存,用户认证等等。

相关推荐
无名之逆5 分钟前
【图论简介】
前端·后端·算法·面试·架构·深度优先·图论
csdn_li_121222 分钟前
使用python导出Excel表格中的lua配置
python·excel·lua
在路上-正出发30 分钟前
【Python】运行tcl、perl程序
python
IT研究室33 分钟前
计算机毕业设计选题推荐-二手物品回收系统-Java/Python项目实战
java·spring boot·python·django·毕业设计·源码·课程设计
fjwangxi1 小时前
Python 数据分析— Numpy 基本操作(下)
python·均值算法·数据分析·numpy
络71 小时前
Spring01——Spring简介、Spring Framework架构、Spring核心概念、IOC入门案例、DI入门案例
java·后端·spring
醉颜凉1 小时前
Eureka:Spring Cloud中的服务注册与发现如何实现?
java·后端·spring·spring cloud·面试·eureka·微服务架构
ac-er88881 小时前
Django-debug-toolbar的作用
python·django·sqlite
一只IT攻城狮1 小时前
idea配置连接数据库的操作方法(适配不同版本)
java·数据库·后端·mysql·intellij-idea
luthane1 小时前
python 实现simpson rule辛普森法则算法
开发语言·python·算法