Python自建chatgpt服务器:使用Flask实现类似Chat服务器流式API接口

引言

使用Flask框架可以轻松实现一个类似chatgpt流式响应的接口,该接口通过POST请求接收prompt和history参数,分别对应为聊天系统的提示词和对话历史,server则给予server-sent event (SSE)返回聊天系统的响应。

服务端

开发前的思考

我们梳理一下,为了实现流式API接口,Server端需要完成的主要工作

1、创建一个flask app, 检查传入的POST请求是否包含JSON,提取必要的数据,并进行验证。
2、响应为SSE: 设置适当的响应头以适应服务器发送事件(text/event-stream),并保持连接活动状态。
3、生成函数: 提供了一个占位符generate()函数。这个函数应包含根据prompt和history生成响应的逻辑。在这个示例中,它简单地流回输入数据。实际开发应当采用真正的LLM大模型,此处从简。
4、流式传输数据: generate()函数设计为持续流式传输数据。在实际应用中,你需要用实际的事件生成逻辑替换循环和time.sleep()。

其中,1比较简单,因为很容易想象处理json数据是Flask的主要工作。3也比较简单,如果使用过大语言模型的产品,你多半会见过打字机式的的UI效果。实际上的大语言模型输出不见得是严格一个个字输出,大概是几个字为单位输出,这是由于其模型输出采用分词器的缘故,即所谓Tokenizer。这不是本文主题,所以我们仅采用一个循环打印来模拟这种返回效果。2和4相对要陌生一些,不过我们可以理解它们就是实现流式接口的必备技术基础,即使没有深入理解也可以实现。正所谓自顶向下的理解一个问题,我们先从最表层的行动:实现(Implementation),开始。

代码实现

严谨起见,首先安装 Flask:

pip install Flask

server部分代码如下

from flask import Flask, request, jsonify, Response

app = Flask(__name__)

@app.route('/api/stream-chat', methods=['POST'])
def stream_chat():
    # Check if the request contains JSON data
    if request.is_json:
        # Get JSON data
        data = request.get_json()

        # Extract 'prompt' field; return an error if it's missing
        prompt = data.get('prompt')
        if prompt is None:
            return jsonify(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BigBookX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值