New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
功能请求:希望标准项目可以实现流式响应 #3282
Comments
直接引用 koa-sse 即可。 |
在Next.js中可以直接将 Next.js// app/api/sse/route.ts
export async function GET() {
const encoder = new TextEncoder()
const stream = new ReadableStream({
async start(controller) {
const data = [
'渐进式设计',
'提供从基础到入门再到企业级的升级方案',
'解决应用维护与拓展性难题',
]
while (data.length) {
const chunk = `data: ${JSON.stringify({ content: data.shift() })}\n\n`
console.log(chunk)
controller.enqueue(encoder.encode(chunk))
await new Promise(resolve => setTimeout(resolve, 100))
}
controller.close()
},
})
return new Response(stream)
} Response Raw
Midway// src/controller/sse.controller.ts
import { Controller, Get, Inject } from '@midwayjs/core'
import type { Context } from '@midwayjs/koa'
@Controller('/api')
export class APIController {
@Inject()
ctx: Context
@Get('/sse')
async createChatCompletion() {
const encoder = new TextEncoder()
const stream = new ReadableStream({
async start(controller) {
const data = [
'渐进式设计',
'提供从基础到入门再到企业级的升级方案',
'解决应用维护与拓展性难题',
]
while (data.length) {
const chunk = `data: ${JSON.stringify({ content: data.shift() })}\n\n`
console.log(chunk)
controller.enqueue(encoder.encode(chunk))
await new Promise(resolve => setTimeout(resolve, 100))
}
controller.close()
},
})
return stream
}
} Response Raw
Logs
|
我们用的 Readable 在 midway 中实现流式响应 const read = new Readable(); // node 内部 stream 模块
read._read = () => {};
read.push(streamData.content); // 异常调用返回一次数据
read.push(null); // 结束的时候 push 一个 null
return read; // 以 read 对象作为响应 |
大兄弟,贴个完整代码参考下 |
标准项目一直都是可以流式响应的。 ctx.res.send(xxx) / ctx.res.end() 即可。 |
这个要具体看sse这个模块里面的逻辑了,你这么引用,所有的请求是都会过它的。 |
有完整案例看看吗,大佬们 |
+1,有无完整例子可以参考看看 |
我刚好写了一个。。。 @Get('/')
async home(): Promise<any> {
this.ctx.status = 200;
this.ctx.set('Transfer-Encoding', 'chunked');
for (let i = 0; i < 100; i++) {
await sleep(100);
this.ctx.res.write('abc'.repeat(100));
}
this.ctx.res.end();
} |
有一个方法可以实现。 如果用 我绕了一圈找现成可用的方式,最后还是回到这个有过一点成果的尝试上。 参考插件代码,我实现了我要的效果 首先把sse.js 拿出来,当作一个服务文件 然后写一个StreamMiddleware中间件 只有以/stream开头的路由会执行这个中间件 import { Middleware, IMiddleware } from '@midwayjs/core';
import { NextFunction, Context } from '@midwayjs/koa';
import { SSETransform } from '../service/sse.service';
// const Stream = require('stream');
const DEFAULT_OPTS = {
maxClients: 10000,
pingInterval: 60000,
closeEvent: 'close',
};
@Middleware()
export class StreamMiddleware implements IMiddleware<Context, NextFunction> {
resolve() {
return async (ctx: Context, next: NextFunction) => {
// 控制器前执行的逻辑
// const startTime = Date.now();
// 执行下一个 Web 中间件,最后执行到控制器
// 这里可以拿到下一个中间件或者控制器的返回值
if (ctx.res.headersSent) {
if (!(ctx.sse instanceof SSETransform)) {
console.error(
'SSE response header has been send, Unable to create the sse response'
);
}
return await next();
}
const sse = new SSETransform(ctx, DEFAULT_OPTS);
sse.on('close', () => {
console.log('close');
});
ctx.sse = sse;
await next();
if (ctx.sse) {
if (!ctx.body) {
ctx.body = ctx.sse;
} else {
if (!ctx.sse.ended) {
ctx.sse.send(ctx.body);
}
ctx.body = sse;
}
}
};
}
match(ctx) {
return ctx.path.indexOf('/stream/') !== -1;
}
} 然后在configuration.ts文件中应用中间件 以上就是我实现的全部流程。 =============== |
我是这样可以实现 |
这是来自QQ邮箱的自动回复邮件。您好,您的邮件已经收到,我会在一周内尽快给您回复!
|
描述
我们希望在标准项目中实现流式响应的功能,以便满足特定应用场景的需求。流式响应允许服务器持续向客户端发送数据,而不需要客户端不断地进行轮询请求,这在某些实时通信和事件推送应用中非常有用。
背景
最近,我们的项目需要与大型语言模型进行交互,以获取实时生成的文本数据。这种交互需要使用 Server-Sent Events (SSE) 协议,其中 content-type 设置为 text/event-stream。在我们的项目中,我们选择使用 Koa 来实现 SSE,具体实现如下:
请求
为了实现流式响应的功能,我们建议在标准项目中提供相应的支持和工具,以便开发人员可以更轻松地创建类似的 SSE 端点。这将使标准项目更加灵活,并能够满足更多实时应用的需求。
预期行为
我们期望标准项目中的流式响应功能包括以下要点:
这些功能将使开发人员能够更方便地实现 SSE 以及其他流式响应协议,从而增强项目的实时通信能力。
相关文档
(以上部分内容由AI协助生成)
The text was updated successfully, but these errors were encountered: